:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}:root{--app-bg: #f7f8fa;--card-bg: #ffffff;--card-bg-alt: #f9fafb;--text: #111827;--text-secondary: #374151;--muted: #6b7280;--muted-light: #9ca3af;--border: #e5e7eb;--border-light: #f3f4f6;--border-focus: #ff8344;--accent: #ff8344;--accent-hover: #e8722f;--accent-light: #fff5ef;--accent-ring: rgba(255, 131, 68, .15);--success: #16a34a;--success-bg: #f0fdf4;--success-border:#bbf7d0;--warning: #ca8a04;--warning-bg: #fefce8;--warning-border:#fde68a;--danger: #dc2626;--danger-bg: #fff5f5;--danger-border: #fecaca;--info: #2563eb;--info-bg: #eff6ff;--info-border: #bfdbfe;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .07), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06), 0 1px 3px rgba(0, 0, 0, .04);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .07), 0 2px 6px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .15), 0 4px 12px rgba(0, 0, 0, .06);--radius-sm: 6px;--radius: 10px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, "SF Mono", Menlo, Monaco, monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: .9375rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--transition: .15s ease;--transition-md: .2s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);background:var(--app-bg, #f7f8fa);min-height:100vh;color:var(--text, #111827)}.page-title{font-size:var(--text-2xl, 1.5rem);font-weight:600;color:var(--text, #111827);margin-bottom:var(--space-6, 24px);line-height:1.3}.page-placeholder{color:var(--muted, #6b7280);font-size:var(--text-sm, .875rem)}.auth-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;background:var(--app-bg)}.page-convertisseur .card-container{display:flex;gap:24px;flex-wrap:wrap;align-items:flex-start}.container{background:var(--card-bg, #fff);border:1px solid var(--border, #e5e7eb);border-radius:var(--radius-lg, 16px);box-shadow:var(--shadow-md, 0 4px 12px rgba(0,0,0,.06));padding:var(--space-8, 32px);max-width:460px;width:100%;text-align:center;height:fit-content;transition:box-shadow var(--transition, .15s ease)}.container:hover{box-shadow:var(--shadow-lg, 0 8px 24px rgba(0,0,0,.07))}header{margin-bottom:var(--space-6, 24px)}h1{font-size:var(--text-xl, 1.25rem);font-weight:600;color:var(--text, #111827);margin-bottom:var(--space-2, 8px)}.subtitle{color:var(--muted, #6b7280);font-size:var(--text-sm, .875rem);line-height:1.5}main{display:flex;flex-direction:column;gap:var(--space-4, 16px)}.drop-zone{border:1.5px dashed var(--border, #d1d5db);border-radius:var(--radius-md, 12px);padding:32px 20px;cursor:pointer;transition:border-color var(--transition),background var(--transition);background:var(--card-bg-alt, #f9fafb)}.drop-zone:hover{border-color:var(--accent, #ff8344);background:var(--accent-light, #fff5ef)}.drop-zone.has-file{border-color:var(--accent, #ff8344);border-style:solid;background:var(--accent-light, #fff5ef)}.drop-hint{color:var(--muted, #6b7280)}.upload-icon{font-size:2rem;display:block;margin-bottom:var(--space-2, 8px);opacity:.6}.drop-hint p{margin:4px 0;font-size:var(--text-sm, .875rem)}.drop-hint .small{font-size:var(--text-xs, .75rem);color:var(--muted-light, #9ca3af)}.file-info{display:flex;align-items:center;justify-content:center;gap:var(--space-3, 12px)}.file-icon{font-size:1.4rem}.file-name{font-weight:500;color:var(--text, #111827);font-size:var(--text-sm, .875rem);word-break:break-all}.submit-btn{background:var(--accent, #ff8344);color:#fff;border:none;padding:11px var(--space-6, 24px);font-size:var(--text-sm, .875rem);font-weight:600;border-radius:var(--radius, 10px);cursor:pointer;transition:background var(--transition),box-shadow var(--transition);font-family:var(--font)}.submit-btn:hover:not(:disabled){background:var(--accent-hover, #e8722f);box-shadow:0 4px 12px #ff83444d}.submit-btn:disabled{opacity:.55;cursor:not-allowed}.submit-btn.uploading{background:var(--muted-light, #9ca3af)}.submit-btn.success{background:var(--success, #16a34a)}.submit-btn.error{background:var(--danger, #dc2626)}.submit-btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring, rgba(255,131,68,.15))}.error-box{background:var(--danger-bg, #fff5f5);border:1px solid var(--danger-border, #fecaca);border-radius:var(--radius, 10px);padding:var(--space-4, 16px);text-align:left;color:var(--danger, #dc2626);font-size:var(--text-sm, .875rem)}.error-box strong{display:block;margin-bottom:var(--space-2, 8px);font-weight:600}.error-box ul{margin-left:var(--space-5, 20px)}.error-box li{margin:3px 0}.error-box details{margin-top:var(--space-3, 12px)}.error-box summary{cursor:pointer;color:var(--muted, #6b7280);font-size:var(--text-xs, .75rem)}.error-box code{display:block;margin-top:var(--space-2, 8px);padding:var(--space-2, 8px);background:var(--border-light, #f3f4f6);border-radius:var(--radius-sm, 6px);font-size:var(--text-xs, .75rem);font-family:var(--font-mono);word-break:break-all;color:var(--text-secondary, #374151)}footer{margin-top:var(--space-6, 24px);padding-top:var(--space-4, 16px);border-top:1px solid var(--border, #e5e7eb)}footer p{font-size:var(--text-xs, .75rem);color:var(--muted-light, #9ca3af)}@media(max-width:500px){.container{padding:var(--space-6, 24px)}h1{font-size:var(--text-lg, 1.125rem)}.drop-zone{padding:24px 16px}}.snackbar-container{position:fixed;bottom:24px;right:24px;z-index:99999;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none}.snackbar{display:flex;align-items:center;gap:10px;padding:12px 18px;border-radius:10px;font-size:13px;font-weight:500;box-shadow:0 4px 20px #00000026;pointer-events:auto;animation:snackbar-in .25s ease-out,snackbar-out .3s ease-in 3.7s forwards;max-width:420px}.snackbar--success{background:#065f46;color:#d1fae5}.snackbar--success svg{color:#34d399}.snackbar--info{background:#78350f;color:#fef3c7}.snackbar--info svg{color:#fbbf24}.snackbar--error{background:#7f1d1d;color:#fecaca}.snackbar--error svg{color:#f87171}@keyframes snackbar-in{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes snackbar-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(8px)}}.sidebar{position:fixed;top:0;left:0;width:232px;height:100vh;background:linear-gradient(160deg,#ff8344,#e8622a 55%,#c44a18);display:flex;flex-direction:column;z-index:50;overflow-y:auto}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.sidebar__logo{padding:22px 20px 20px;border-bottom:1px solid rgba(255,255,255,.12)}.sidebar__logo img{max-width:72px;height:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.95}.sidebar__nav{flex:1;padding:14px 10px;display:flex;flex-direction:column;gap:1px}.sidebar__section{display:flex;flex-direction:column;gap:1px;margin-bottom:18px}.sidebar__section-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffff61;padding:0 11px;margin-bottom:4px}.sidebar__section-empty{font-size:12px;color:#ffffff4d;padding:6px 11px;font-style:italic}.sidebar-item{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:8px;text-decoration:none;color:#ffffffa6;font-size:13px;font-weight:500;letter-spacing:.01em;transition:background .15s cubic-bezier(.4,0,.2,1),color .15s cubic-bezier(.4,0,.2,1);position:relative;-webkit-user-select:none;user-select:none}.sidebar-item:hover{background:#0000001a;color:#ffffffeb}.sidebar-item--active{background:#0000002e;color:#fff;font-weight:600}.sidebar-item--active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:16px;background:#ffffffe6;border-radius:0 3px 3px 0}.sidebar-item--disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.sidebar-item--premium-locked{opacity:.6;cursor:not-allowed;pointer-events:none}.sidebar-item__crown{display:flex;align-items:center;gap:4px;font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#1a1a1a;background:#ffe87a;padding:2px 6px 2px 4px;border-radius:999px;flex-shrink:0;white-space:nowrap}.sidebar-item__badge{font-size:9px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#ffffff8c;background:#ffffff1f;padding:2px 6px;border-radius:999px;flex-shrink:0}.sidebar-item:focus-visible{outline:none;box-shadow:0 0 0 2px #ffffff59}.sidebar-item__icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.75;transition:opacity .15s ease}.sidebar-item:hover .sidebar-item__icon{opacity:.9}.sidebar-item--active .sidebar-item__icon{opacity:1}.sidebar-item__label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__footer{padding:10px;border-top:1px solid rgba(255,255,255,.1)}.sidebar__logout{display:flex;align-items:center;gap:9px;width:100%;padding:8px 11px;border-radius:8px;border:none;background:transparent;color:#ffffff80;font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .15s cubic-bezier(.4,0,.2,1),color .15s cubic-bezier(.4,0,.2,1);text-align:left;letter-spacing:.01em}.sidebar__logout:hover{background:#0000001a;color:#fffc}.dashboard-layout{min-height:100vh;background:var(--app-bg)}.dashboard-layout__main{margin-left:232px;display:flex;flex-direction:column;min-height:100vh}.dashboard-layout__header{position:sticky;top:0;z-index:40;height:56px;background:#fff;border-bottom:2px solid #ff8344;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);flex-shrink:0;gap:var(--space-3)}.dashboard-layout__badges{display:flex;align-items:center;gap:var(--space-3)}.dashboard-layout__user{display:flex;align-items:center;gap:var(--space-2)}.dashboard-layout__avatar{width:30px;height:30px;border-radius:var(--radius-full);background:linear-gradient(135deg,#ff8344,#c44a18);border:none;display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;color:#fff;flex-shrink:0}.dashboard-layout__email{font-size:var(--text-xs);color:var(--muted);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-layout__plan{display:flex;align-items:center;gap:var(--space-2);background:var(--border-light);border:1px solid var(--border);border-radius:var(--radius-full);padding:4px 12px 4px 10px}.dashboard-layout__plan-label{font-size:var(--text-xs);font-weight:500;color:var(--muted);letter-spacing:.02em}.dashboard-layout__plan-badge{display:inline-block;padding:2px 9px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em}.dashboard-layout__plan-badge--free{background:#e5e7eb;color:#6b7280}.dashboard-layout__plan-badge--basic{background:#dbeafe;color:#1d4ed8}.dashboard-layout__plan-badge--premium{background:#f3e8ff;color:#7c3aed}.dashboard-layout__trial{font-size:var(--text-xs);color:var(--muted);border-left:1px solid var(--border);padding-left:var(--space-2);margin-left:var(--space-1)}.dashboard-layout__quota{display:flex;align-items:center;gap:var(--space-2);background:var(--border-light);border:1px solid var(--border);border-radius:var(--radius-full);padding:4px 12px 4px 10px}.dashboard-layout__quota-label{font-size:var(--text-xs);font-weight:500;color:var(--muted)}.dashboard-layout__quota-value{font-size:var(--text-xs);font-weight:700;color:var(--text);background:#fff;border:1px solid var(--border);border-radius:var(--radius-full);padding:1px 8px}.dashboard-layout__quota-value--full{color:var(--danger);border-color:var(--danger-border);background:var(--danger-bg)}.dashboard-layout__content{flex:1;padding:var(--space-8);overflow-y:auto;overflow-x:hidden;min-width:0}.dashboard-layout__inner{width:100%;min-width:0}.admin-page{width:100%}.admin-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6);margin-bottom:var(--space-6);transition:box-shadow var(--transition)}.admin-section:hover{box-shadow:var(--shadow-md)}.admin-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.admin-section__title{font-size:var(--text-base);font-weight:600;color:var(--text)}.admin-section__count{font-size:var(--text-xs);color:var(--muted);background:var(--border-light);padding:2px var(--space-2);border-radius:var(--radius-full);margin-left:var(--space-2)}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.admin-table th{text-align:left;padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:var(--space-3);border-bottom:1px solid var(--border-light);color:var(--text-secondary);vertical-align:middle}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table tbody tr:hover td{background:var(--card-bg-alt)}.badge{display:inline-flex;align-items:center;padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600}.badge--green{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.badge--red{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.badge--orange{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.badge--gray{background:var(--border-light);color:var(--muted);border:1px solid var(--border)}.badge--blue{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:7px var(--space-3);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;font-family:var(--font);border:1px solid transparent;cursor:pointer;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition);white-space:nowrap;outline:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{box-shadow:0 0 0 3px var(--accent-ring)}.btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn--primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn--danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-border)}.btn--danger:hover:not(:disabled){background:var(--danger-border)}.btn--success{background:var(--success-bg);color:var(--success);border-color:var(--success-border)}.btn--success:hover:not(:disabled){background:var(--success-border)}.btn--outline{background:transparent;color:var(--text-secondary);border-color:var(--border)}.btn--outline:hover:not(:disabled){background:var(--card-bg-alt);color:var(--text)}.btn--sm{padding:4px var(--space-2);font-size:var(--text-xs)}.btn-group{display:flex;gap:var(--space-2)}.invite-code-box{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--card-bg-alt);border:1px solid var(--border);border-radius:var(--radius)}.invite-code-value{font-family:ui-monospace,monospace;font-size:var(--text-base);font-weight:700;letter-spacing:.08em;color:var(--text);flex:1}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.stat-card{background:var(--card-bg-alt);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);transition:box-shadow var(--transition)}.stat-card:hover{box-shadow:var(--shadow-sm)}.stat-card__label{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.stat-card__value{font-size:2rem;font-weight:800;color:var(--text);line-height:1}.stat-card__value--accent{color:var(--accent)}.modal-overlay{position:fixed;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-5)}.modal{background:var(--card-bg);border-radius:var(--radius-lg);padding:var(--space-6);max-width:420px;width:100%;box-shadow:var(--shadow-xl);border:1px solid var(--border)}.modal__title{font-size:var(--text-base);font-weight:600;color:var(--text);margin-bottom:var(--space-2)}.modal__body{color:var(--muted);font-size:var(--text-sm);line-height:1.6;margin-bottom:var(--space-6)}.modal__actions{display:flex;gap:var(--space-3);justify-content:flex-end}.admin-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-12);color:var(--muted-light);font-size:var(--text-sm)}.admin-empty{padding:var(--space-8);text-align:center;color:var(--muted-light);font-size:var(--text-sm)}.admin-error{padding:var(--space-3) var(--space-4);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius);color:var(--danger);font-size:var(--text-sm);margin-bottom:var(--space-4)}.admin-table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-3);flex-wrap:wrap}.admin-search{display:flex;align-items:center;gap:var(--space-2);background:var(--card-bg-alt);border:1px solid var(--border);border-radius:var(--radius);padding:5px var(--space-3);min-width:220px;transition:border-color var(--transition)}.admin-search:focus-within{border-color:var(--accent)}.admin-search__icon{color:var(--muted-light);font-size:.9rem;flex-shrink:0}.admin-search__input{border:none;background:transparent;outline:none;font-size:var(--text-sm);font-family:var(--font);color:var(--text);width:100%;min-width:0}.admin-search__input::placeholder{color:var(--muted-light)}.admin-pagination{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-3);justify-content:center}.admin-page-btn{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:30px;height:30px;font-size:1rem;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition);line-height:1}.admin-page-btn:hover:not(:disabled){background:var(--border-light);color:var(--text)}.admin-page-btn:disabled{opacity:.35;cursor:not-allowed}.admin-page-info{font-size:var(--text-xs);color:var(--muted);min-width:56px;text-align:center}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2);z-index:200}.toast{padding:var(--space-3) var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;box-shadow:var(--shadow-lg);animation:slideIn .2s ease;max-width:320px}.toast--success{background:var(--success);color:#fff}.toast--error{background:var(--danger);color:#fff}@keyframes slideIn{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.adminmsg-form{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.adminmsg-textarea{width:100%;padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--text-sm);font-family:var(--font);color:var(--text);background:var(--card-bg);resize:vertical;box-sizing:border-box;transition:border-color var(--transition)}.adminmsg-textarea:focus{outline:none;border-color:#ff8344}.adminmsg-form__bottom{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.adminmsg-colors{display:flex;gap:var(--space-2)}.adminmsg-color{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:transform var(--transition),box-shadow var(--transition)}.adminmsg-color:hover{transform:scale(1.15)}.adminmsg-color--selected{box-shadow:0 0 0 2px #fff,0 0 0 4px currentColor}.adminmsg-color--orange{background:#fb923c}.adminmsg-color--blue{background:#3b82f6}.adminmsg-color--green{background:#22c55e}.adminmsg-color--red{background:#ef4444}.adminmsg-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.adminmsg-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);transition:opacity var(--transition)}.adminmsg-item--inactive{opacity:.5}.adminmsg-item__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.adminmsg-item__content{flex:1;font-size:var(--text-sm);color:var(--text)}.adminmsg-item__actions{display:flex;gap:var(--space-2);flex-shrink:0}.adminmsg-delete{color:#dc2626!important;border-color:#fecaca!important}.adminmsg-delete:hover{background:#fee2e2!important}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;gap:8px}.empty-state__icon{font-size:32px;line-height:1;display:block;margin-bottom:4px}.empty-state__title{font-size:1rem;font-weight:700;color:#111827;margin:0}.empty-state__description{font-size:.875rem;color:#6b7280;line-height:1.5;margin:0;max-width:320px}.empty-state__action{margin-top:8px}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:#f3f4f6;background-image:linear-gradient(90deg,#f3f4f6,#e9eaec,#f3f4f6 80px);background-size:800px 100%;animation:skeleton-shimmer 1.4s ease-in-out infinite;border-radius:6px;display:block}.skeleton--hidden{visibility:hidden}.skeleton--text{height:14px;border-radius:4px;width:100%}.skeleton--text-short{height:14px;border-radius:4px;width:60%}.skeleton--card{height:80px;border-radius:10px;width:100%}.skeleton--row{height:44px;border-radius:6px;width:100%}.skeleton--image{aspect-ratio:1;border-radius:10px;width:100%}.skeleton-rows{display:flex;flex-direction:column;gap:6px;padding-top:8px}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;margin-top:16px}.charts-grid{display:grid;gap:var(--space-5);margin-bottom:var(--space-6)}.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}.chart-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition)}.chart-card:hover{box-shadow:var(--shadow-md)}.chart-card__title{font-size:var(--text-sm);font-weight:600;color:var(--text);margin-bottom:var(--space-4);display:flex;align-items:center;gap:var(--space-2)}.chart-card__title-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.chart-tooltip{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;box-shadow:var(--shadow-md);font-size:var(--text-xs);color:var(--text);pointer-events:none}.chart-tooltip__label{color:var(--muted);margin-bottom:4px;font-size:calc(var(--text-xs) - 1px)}.chart-tooltip__value{font-weight:700;font-size:var(--text-sm);font-variant-numeric:tabular-nums}.chart-legend{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center;margin-top:var(--space-4)}.chart-legend__item{display:flex;align-items:center;gap:6px;font-size:var(--text-xs);color:var(--text-secondary);line-height:1}.chart-legend__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.chart-legend__pct{color:var(--muted);font-size:calc(var(--text-xs) - 1px)}.chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:180px;color:var(--muted-light);font-size:var(--text-sm);gap:var(--space-2)}.chart-empty__icon{font-size:2rem;opacity:.4}.chart-skeleton{border-radius:var(--radius);background:linear-gradient(90deg,var(--border-light) 25%,var(--border) 50%,var(--border-light) 75%);background-size:200% 100%;animation:chartShimmer 1.4s infinite}.chart-skeleton--area{height:220px}.chart-skeleton--pie{height:260px}@keyframes chartShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:900px){.charts-row{grid-template-columns:1fr}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in-wrapper{animation:fade-in-up .22s ease-out both}.eco-page{width:100%}.eco-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6);margin-bottom:var(--space-6);transition:box-shadow var(--transition)}.eco-section:hover{box-shadow:var(--shadow-md)}.eco-section__title{font-size:var(--text-base);font-weight:600;color:var(--text);margin-bottom:var(--space-5)}.eco-form{display:flex;flex-direction:column;gap:var(--space-5)}.eco-field{display:flex;flex-direction:column;gap:var(--space-2)}.eco-field__label{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.eco-input{padding:9px var(--space-3);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--text-sm);color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition);font-family:var(--font);background:var(--card-bg)}.eco-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.eco-input::placeholder{color:var(--muted-light)}.eco-radio-group{display:flex;gap:var(--space-2);flex-wrap:wrap}.eco-radio-option{display:flex;align-items:center}.eco-radio-option input[type=radio]{display:none}.eco-radio-option label{padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--card-bg);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:border-color var(--transition),background var(--transition),color var(--transition);-webkit-user-select:none;user-select:none}.eco-radio-option input[type=radio]:checked+label{border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:600}.eco-radio-option label:hover{border-color:var(--accent);color:var(--accent)}.eco-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:9px var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;font-family:var(--font);border:1px solid transparent;cursor:pointer;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition);white-space:nowrap;outline:none;align-self:flex-start}.eco-btn:disabled{opacity:.5;cursor:not-allowed}.eco-btn:focus-visible{box-shadow:0 0 0 3px var(--accent-ring)}.eco-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.eco-btn--primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.eco-error{padding:var(--space-3) var(--space-4);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius);color:var(--danger);font-size:var(--text-sm);margin-bottom:var(--space-4)}.eco-loading{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) 0;color:var(--muted-light);font-size:var(--text-sm)}.eco-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:eco-spin .7s linear infinite;flex-shrink:0}@keyframes eco-spin{to{transform:rotate(360deg)}}.eco-result{display:flex;flex-direction:column;gap:var(--space-4)}.eco-result__amount-card{text-align:center;padding:var(--space-7) var(--space-5);background:var(--accent-light);border:1.5px solid var(--accent);border-radius:var(--radius-md)}.eco-result__amount-label{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2)}.eco-result__amount-value{font-size:2.5rem;font-weight:800;color:var(--accent);line-height:1}.eco-result__amount-value--null{font-size:var(--text-lg);font-weight:600;color:var(--muted-light)}.eco-result__meta{display:flex;flex-direction:column;gap:var(--space-2)}.eco-result__row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--card-bg-alt);border:1px solid var(--border);border-radius:var(--radius)}.eco-result__row-label{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.eco-result__row-value{font-size:var(--text-sm);color:var(--text);text-align:right}.eco-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600}.eco-badge--élevée{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.eco-badge--moyenne{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.eco-badge--faible{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.eco-result__warning{padding:var(--space-3) var(--space-4);background:var(--warning-bg);border:1px solid var(--warning-border);border-radius:var(--radius);font-size:var(--text-xs);color:var(--warning);line-height:1.5}.images-page{width:100%}.images-layout{display:grid;grid-template-columns:220px 1fr;gap:var(--space-6);align-items:start}.images-sidebar{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-4);position:sticky;top:var(--space-6)}.images-sidebar__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border)}.images-sidebar__title{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.images-sidebar__add-btn{width:24px;height:24px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--muted);font-size:1.1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}.images-sidebar__add-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.images-sidebar__new-folder{margin-bottom:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.images-sidebar__new-folder-input{width:100%;padding:6px 10px;font-size:var(--text-sm);font-family:var(--font);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg-alt);color:var(--text);outline:none;box-sizing:border-box;transition:border-color var(--transition),box-shadow var(--transition)}.images-sidebar__new-folder-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.images-sidebar__new-folder-actions{display:flex;gap:var(--space-2)}.images-sidebar__nav{display:flex;flex-direction:column;gap:2px}.images-sidebar__divider{height:1px;background:var(--border);margin:var(--space-2) 0}.images-sidebar__folder-row{display:flex;align-items:center;gap:2px;position:relative}.images-sidebar__folder-row:hover .images-sidebar__folder-actions{opacity:1;pointer-events:auto}.images-sidebar__item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:7px var(--space-2);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:var(--text-sm);font-family:var(--font);cursor:pointer;text-align:left;transition:background var(--transition),color var(--transition);flex:1;min-width:0}.images-sidebar__item:hover{background:var(--border-light);color:var(--text)}.images-sidebar__item--active{background:var(--accent-light);color:var(--accent);font-weight:600}.images-sidebar__item--active:hover{background:var(--accent-light)}.images-sidebar__item-icon{font-size:.9rem;flex-shrink:0}.images-sidebar__item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.images-sidebar__item-count{flex-shrink:0;font-size:var(--text-xs);color:var(--muted-light);background:var(--border-light);border-radius:20px;padding:1px 7px;min-width:20px;text-align:center}.images-sidebar__item--active .images-sidebar__item-count{background:var(--accent);color:#fff}.images-sidebar__folder-actions{display:flex;gap:2px;opacity:0;pointer-events:none;flex-shrink:0;transition:opacity var(--transition)}.images-sidebar__folder-action{width:22px;height:22px;border:none;border-radius:var(--radius-sm);background:transparent;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:background var(--transition)}.images-sidebar__folder-action:hover{background:var(--border-light)}.images-sidebar__folder-action--danger:hover{background:var(--danger-bg)}.images-sidebar__folder-action:disabled{opacity:.4;cursor:not-allowed}.images-sidebar__rename{display:flex;align-items:center;gap:4px;flex:1;padding:2px var(--space-1)}.images-sidebar__rename-input{flex:1;min-width:0;padding:4px 8px;font-size:var(--text-sm);font-family:var(--font);border:1px solid var(--accent);border-radius:var(--radius-sm);background:var(--card-bg-alt);color:var(--text);outline:none;box-shadow:0 0 0 2px var(--accent-ring)}.images-sidebar__rename-ok,.images-sidebar__rename-cancel{width:22px;height:22px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.images-sidebar__rename-ok{background:var(--success-bg);color:var(--success)}.images-sidebar__rename-ok:hover{background:var(--success);color:#fff}.images-sidebar__rename-cancel{background:var(--border-light);color:var(--muted)}.images-sidebar__rename-cancel:hover{background:var(--danger-bg);color:var(--danger)}.images-main{display:flex;flex-direction:column;gap:var(--space-6);min-width:0}.images-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:box-shadow var(--transition)}.images-section:hover{box-shadow:var(--shadow-md)}.images-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);gap:var(--space-4)}.images-section__title{font-size:var(--text-base);font-weight:600;color:var(--text);margin-bottom:var(--space-4)}.images-section__header .images-section__title{margin-bottom:0}.images-gallery-count{font-weight:400;color:var(--muted);font-size:var(--text-sm)}.images-upload-folder-selector{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.images-upload-folder-selector__label{font-size:var(--text-xs);color:var(--muted);white-space:nowrap}.images-upload-folder-selector__select{padding:5px 10px;font-size:var(--text-sm);font-family:var(--font);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg-alt);color:var(--text);cursor:pointer;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.images-upload-folder-selector__select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.images-upload-folder-selector__select:disabled{opacity:.5;cursor:not-allowed}.images-dropzone{border:1.5px dashed var(--border);border-radius:var(--radius-md);padding:var(--space-10) var(--space-5);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);cursor:pointer;transition:border-color var(--transition),background var(--transition);text-align:center;background:var(--card-bg-alt)}.images-dropzone:hover,.images-dropzone--drag{border-color:var(--accent);background:var(--accent-light)}.images-dropzone--disabled{opacity:.5;cursor:not-allowed}.images-dropzone__icon{font-size:2rem;line-height:1;color:var(--muted-light)}.images-dropzone__label{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.images-dropzone__sub{font-size:var(--text-xs);color:var(--muted-light)}.images-dropzone__cta{display:inline-flex;align-items:center;gap:var(--space-2);margin-top:var(--space-1);padding:9px var(--space-4);background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;font-family:var(--font);cursor:pointer;transition:background var(--transition),box-shadow var(--transition);outline:none}.images-dropzone__cta:hover:not(:disabled){background:var(--accent-hover)}.images-dropzone__cta:focus-visible{box-shadow:0 0 0 3px var(--accent-ring)}.images-dropzone__cta:disabled{opacity:.5;cursor:not-allowed}.images-previews{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--space-3);margin-top:var(--space-5)}.images-preview-item{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--card-bg-alt);aspect-ratio:1}.images-preview-item img{width:100%;height:100%;object-fit:cover;display:block}.images-preview-item__remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#0000008c;color:#fff;border:none;cursor:pointer;font-size:var(--text-xs);display:flex;align-items:center;justify-content:center;line-height:1;transition:background var(--transition)}.images-preview-item__remove:hover{background:#dc2626d9}.images-preview-item__name{position:absolute;bottom:0;left:0;right:0;background:#00000073;color:#fff;font-size:.65rem;padding:3px 5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.images-actions{display:flex;gap:var(--space-3);margin-top:var(--space-5);align-items:center}.images-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:9px var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;font-family:var(--font);border:1px solid transparent;cursor:pointer;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition);white-space:nowrap;outline:none}.images-btn:disabled{opacity:.5;cursor:not-allowed}.images-btn:focus-visible{box-shadow:0 0 0 3px var(--accent-ring)}.images-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.images-btn--primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.images-btn--secondary{background:var(--border-light);color:var(--text-secondary);border-color:var(--border)}.images-btn--secondary:hover:not(:disabled){background:var(--border);color:var(--text)}.images-btn--outline{background:transparent;color:var(--muted);border-color:var(--border);padding:5px 10px;font-size:var(--text-xs);border-radius:var(--radius-sm)}.images-btn--outline:hover:not(:disabled){background:var(--border-light);color:var(--text-secondary)}.images-btn--outline.copied{border-color:var(--success-border);color:var(--success);background:var(--success-bg)}.images-btn--xs{padding:5px 10px;font-size:var(--text-xs)}.images-error{padding:var(--space-3) var(--space-4);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius);color:var(--danger);font-size:var(--text-sm);margin-bottom:var(--space-4)}.images-error ul{margin:var(--space-1) 0 0 var(--space-4);padding:0}.images-error li{margin-bottom:2px}.images-loading{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) 0;color:var(--muted-light);font-size:var(--text-sm)}.images-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:images-spin .7s linear infinite;flex-shrink:0}@keyframes images-spin{to{transform:rotate(360deg)}}.images-spinner--inline{display:inline-block;width:13px;height:13px;flex-shrink:0;vertical-align:middle}.images-clean-result{margin-top:var(--space-5)}.images-clean-banner{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--success-bg);border:1px solid var(--success-border);border-radius:var(--radius);color:var(--success);font-size:var(--text-sm)}.images-clean-banner__icon{font-size:1rem;font-weight:700;flex-shrink:0}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-4)}.images-grid-item{border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);background:var(--card-bg-alt);display:flex;flex-direction:column;transition:box-shadow var(--transition)}.images-grid-item:hover{box-shadow:var(--shadow-sm)}.images-grid-item__img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.images-grid-item__bar{display:flex;gap:var(--space-2);padding:var(--space-2);background:var(--card-bg);border-top:1px solid var(--border);align-items:center}.images-grid-item__bar .images-btn--outline{flex:1;justify-content:center;font-size:var(--text-xs);padding:5px 8px}.images-grid-item__actions{display:flex;gap:4px;flex-shrink:0}.images-grid-item__icon-btn{flex-shrink:0;width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),border-color var(--transition)}.images-grid-item__icon-btn:hover:not(:disabled){background:var(--border-light);border-color:var(--accent)}.images-grid-item__icon-btn:disabled{opacity:.4;cursor:not-allowed}.images-grid-item__delete{flex-shrink:0;width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--danger-border);background:transparent;color:var(--danger);font-size:var(--text-xs);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition)}.images-grid-item__delete:hover:not(:disabled){background:var(--danger-bg);border-color:var(--danger)}.images-grid-item__delete:disabled{opacity:.4;cursor:not-allowed}.images-grid-item__move-wrap{position:relative}.move-menu{position:absolute;bottom:calc(100% + 6px);right:0;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:170px;z-index:100;overflow:hidden}.move-menu__title{font-size:var(--text-xs);color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border)}.move-menu__item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:8px var(--space-3);border:none;background:transparent;color:var(--text-secondary);font-size:var(--text-sm);font-family:var(--font);cursor:pointer;text-align:left;transition:background var(--transition),color var(--transition)}.move-menu__item:hover{background:var(--border-light);color:var(--text)}.move-menu__item--active{color:var(--accent);font-weight:600}.move-menu__icon{font-size:.85rem}.images-gallery-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.images-gallery-header__left{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}.images-select-all{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.images-select-all:hover{color:var(--text-secondary)}.images-select-all input[type=checkbox]{cursor:pointer;accent-color:var(--accent)}.images-grid-item--selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-ring)}.images-grid-item__checkbox{position:absolute;top:6px;left:6px;z-index:2;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:#ffffffd9;box-shadow:0 1px 3px #00000026;opacity:0;transition:opacity var(--transition);cursor:pointer}.images-grid-item:hover .images-grid-item__checkbox,.images-grid-item--selected .images-grid-item__checkbox{opacity:1}.images-grid-item__checkbox input[type=checkbox]{cursor:pointer;accent-color:var(--accent);margin:0}.images-grid-item{position:relative}.images-btn--danger-solid{background:var(--danger);color:#fff;border-color:var(--danger)}.images-btn--danger-solid:hover:not(:disabled){background:#b91c1c;border-color:#b91c1c}.selection-bar{position:fixed;bottom:var(--space-6);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-5);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg, 0 10px 25px rgba(0, 0, 0, .15));z-index:200;white-space:nowrap;animation:selection-bar-in .18s ease}@keyframes selection-bar-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.selection-bar__count{font-size:var(--text-sm);font-weight:600;color:var(--text)}.selection-bar__actions{display:flex;align-items:center;gap:var(--space-2)}.selection-bar__move-wrap{position:relative}.selection-bar__clear{width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}.selection-bar__clear:hover:not(:disabled){background:var(--border-light);color:var(--text)}.selection-bar__clear:disabled{opacity:.4;cursor:not-allowed}.move-menu--up{bottom:calc(100% + 6px);top:auto}.images-drag-ghost{position:fixed;top:-9999px;left:-9999px;padding:6px 12px;background:var(--accent);color:#fff;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;font-family:var(--font);pointer-events:none;white-space:nowrap;box-shadow:0 4px 12px #0003}.images-sidebar__item--drop-target{background:var(--accent-light)!important;color:var(--accent)!important;border:1.5px dashed var(--accent);outline:none}@media(max-width:900px){.images-layout{grid-template-columns:1fr}.images-sidebar{position:static}.images-sidebar__nav{flex-direction:row;flex-wrap:wrap;gap:var(--space-2)}.images-sidebar__folder-row{flex:0 0 auto}.images-sidebar__item{width:auto;padding:6px var(--space-3)}.images-sidebar__divider{display:none}.images-sidebar__folder-actions{opacity:1;pointer-events:auto}}@media(max-width:600px){.images-section__header{flex-direction:column;align-items:flex-start}.images-actions{flex-wrap:wrap}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f9fafb;padding:24px}.auth-card{background:linear-gradient(160deg,#ff8344,#e8622a 55%,#c44a18);border-radius:16px;box-shadow:0 8px 32px #c44a1859;padding:40px;width:100%;max-width:400px;text-align:center}.auth-logo{max-width:72px;height:auto;margin-bottom:20px;filter:brightness(0) invert(1)}.auth-title{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:16px;text-align:left}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:.875rem;font-weight:500;color:#ffffffe6}.auth-field input{padding:10px 14px;border:1px solid rgba(255,255,255,.4);border-radius:8px;font-size:.95rem;color:#111827;background:#fffffff2;outline:none;transition:border-color .15s ease}.auth-field input:focus{border-color:#fff;box-shadow:0 0 0 3px #ffffff4d}.auth-error{font-size:.875rem;color:#dc2626;background:#fff5f5;border:1px solid #fecaca;border-radius:8px;padding:10px 12px;text-align:left}.auth-btn{background:#fff;color:#c44a18;border:none;border-radius:8px;padding:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s ease,transform .1s ease,box-shadow .15s ease;margin-top:4px}.auth-btn:hover:not(:disabled){background:#ffffffe6;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.auth-btn:disabled{opacity:.65;cursor:not-allowed}.auth-footer{margin-top:20px;font-size:.875rem;color:#fffc}.auth-footer a{color:#fff;font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-input-wrap{position:relative;display:flex;align-items:center}.auth-input-wrap input{width:100%;padding-right:40px}.auth-eye-btn{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:#9ca3af;display:flex;align-items:center;padding:0;line-height:1}.auth-eye-btn:hover{color:#374151}.auth-forgot{text-align:right;margin-top:-4px}.auth-forgot a{font-size:.8rem;color:#ffffffbf;text-decoration:none}.auth-forgot a:hover{color:#fff;text-decoration:underline}.auth-hint{font-size:.75rem;color:#fff9;margin-top:2px}.auth-success{font-size:.9rem;color:#fff;background:#ffffff26;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:12px 14px;text-align:center;margin-bottom:8px}.auth-loading,.auth-blocked{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#6b7280;font-size:.95rem}.auth-blocked h2{font-size:1.25rem;color:#111827}.optim-history{margin-top:var(--space-6)}.optim-history__header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.optim-history__filters{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-4);align-items:center}.optim-history__filter-select{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:var(--text-sm);font-family:var(--font);color:var(--text-secondary);background:var(--card-bg);outline:none;cursor:pointer;transition:border-color var(--transition)}.optim-history__filter-select:focus{border-color:var(--accent)}.optim-history__pagination{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-top:var(--space-4)}.optim-history__page-btn{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:32px;height:32px;font-size:1.1rem;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}.optim-history__page-btn:hover:not(:disabled){background:var(--border-light);color:var(--text)}.optim-history__page-btn:disabled{opacity:.35;cursor:not-allowed}.optim-history__page-info{font-size:var(--text-sm);color:var(--muted);min-width:60px;text-align:center}.optim-history__title{font-size:var(--text-base);font-weight:600;color:var(--text)}.optim-history__count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:var(--radius-full);background:var(--accent-light);color:var(--accent);font-size:var(--text-xs);font-weight:700}.optim-history-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg)}.optim-history-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.optim-history-table thead th{padding:10px var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;background:var(--card-bg-alt);border-bottom:1px solid var(--border);white-space:nowrap}.optim-history-table tbody tr{cursor:pointer;border-bottom:1px solid var(--border);transition:background var(--transition)}.optim-history-table tbody tr:last-child{border-bottom:none}.optim-history-table tbody tr:hover{background:var(--hover-bg, #f9fafb)}.optim-history-table tbody tr.selected{background:#ff83440f}.optim-history-table td{padding:12px var(--space-4);vertical-align:middle}.optim-history__cell-title{font-weight:500;color:var(--text);max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.optim-history__cell-meta{color:var(--text-secondary);white-space:nowrap}.optim-history__cell-date{color:var(--muted-light);font-size:var(--text-xs);white-space:nowrap}.optim-history__delete{background:none;border:none;cursor:pointer;color:var(--muted-light);font-size:1rem;padding:4px 6px;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition);line-height:1}.optim-history__delete:hover{color:var(--danger);background:var(--danger-bg)}.optim-history-detail{margin-top:var(--space-4);border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--card-bg);box-shadow:var(--shadow-sm);overflow:hidden}.optim-history-detail__bar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);background:var(--card-bg-alt)}.optim-history-detail__bar-title{font-size:var(--text-sm);font-weight:600;color:var(--text)}.optim-history-detail__close{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1.1rem;padding:4px 8px;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition);line-height:1}.optim-history-detail__close:hover{color:var(--text);background:var(--border-light)}.optim-history-detail__body{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-5)}.optim-history-detail__section-label{font-size:var(--text-xs);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.optim-history-detail__inputs{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-3)}.optim-history-detail__input-item{background:var(--card-bg-alt);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.optim-history-detail__input-key{font-size:var(--text-xs);color:var(--muted);margin-bottom:4px}.optim-history-detail__input-val{font-size:var(--text-sm);font-weight:500;color:var(--text);white-space:pre-wrap;word-break:break-word}.optim-page{width:100%}.optim-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-6);margin-bottom:var(--space-6);transition:box-shadow var(--transition)}.optim-section:hover{box-shadow:var(--shadow-md)}.optim-section__title{font-size:var(--text-base);font-weight:600;color:var(--text);margin-bottom:var(--space-5)}.optim-selectors{display:flex;gap:var(--space-6);flex-wrap:wrap}.optim-chip-group{display:flex;gap:var(--space-2);flex-wrap:wrap}.optim-chip{padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--card-bg);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:border-color var(--transition),background var(--transition),color var(--transition);font-family:var(--font)}.optim-chip:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.optim-chip--active{border-color:var(--accent);background:var(--accent-light);color:var(--accent);font-weight:600}.optim-chip:disabled{opacity:.5;cursor:not-allowed}.optim-hint{margin-top:var(--space-3);font-size:var(--text-xs);color:var(--muted-light)}.optim-preview{display:flex;flex-direction:column;gap:var(--space-4)}.optim-field{display:flex;flex-direction:column;gap:var(--space-2)}.optim-field__label{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.optim-url-input{padding:9px var(--space-3);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--text-sm);font-family:var(--font);color:var(--text);background:var(--card-bg);outline:none;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.optim-url-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.optim-url-input::placeholder{color:var(--muted-light)}.optim-url-input:disabled{opacity:.6;background:var(--border-light);cursor:not-allowed}.optim-textarea{resize:vertical;min-height:120px;line-height:1.6}.optim-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:9px var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;font-family:var(--font);border:1px solid transparent;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition);white-space:nowrap;outline:none}.optim-btn:disabled{opacity:.5;cursor:not-allowed}.optim-btn:focus-visible{box-shadow:0 0 0 3px var(--accent-ring)}.optim-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.optim-btn--primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.optim-btn--secondary{background:var(--border-light);color:var(--text-secondary);border-color:var(--border)}.optim-btn--secondary:hover:not(:disabled){background:var(--border);color:var(--text)}.optim-btn--outline{background:transparent;color:var(--muted);border-color:var(--border);padding:5px 10px;font-size:var(--text-xs);border-radius:var(--radius-sm)}.optim-btn--outline:hover:not(:disabled){background:var(--border-light);color:var(--text-secondary)}.optim-btn--outline.copied{border-color:var(--success-border);color:var(--success);background:var(--success-bg)}.optim-results{display:flex;flex-direction:column;gap:var(--space-4)}.optim-result-card{background:var(--card-bg-alt);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5)}.optim-result-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3);gap:var(--space-3)}.optim-result-card__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.optim-btn--html{color:var(--muted);border-style:dashed}.optim-result-card__label{font-size:var(--text-xs);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.optim-result-card__value{font-size:var(--text-sm);color:var(--text);line-height:1.65;white-space:pre-wrap;word-break:break-word}.optim-result-card__value--bullets{padding-bottom:var(--space-3);margin-bottom:var(--space-3);border-bottom:1px solid var(--border)}.optim-notes{padding:var(--space-3) var(--space-4);background:var(--success-bg);border:1px solid var(--success-border);border-radius:var(--radius);font-size:var(--text-sm);color:var(--success);line-height:1.5}.optim-error{padding:var(--space-3) var(--space-4);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius);color:var(--danger);font-size:var(--text-sm);margin-bottom:var(--space-4)}.optim-loading{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) 0;color:var(--muted-light);font-size:var(--text-sm)}.optim-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:600px){.optim-selectors{flex-direction:column;gap:var(--space-4)}}.produits-page{padding:var(--space-6);max-width:1500px}.produits-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5);gap:var(--space-4);flex-wrap:wrap}.produits-header__title{font-size:1.25rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.produits-header__actions{display:flex;gap:var(--space-3);align-items:center}.produits-search{position:relative;display:flex;align-items:center}.produits-search__icon{position:absolute;left:10px;color:var(--muted);pointer-events:none;flex-shrink:0}.produits-search__input{padding:7px 12px 7px 32px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);width:220px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.produits-search__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.produits-search__input::placeholder{color:var(--muted);opacity:.6}.produits-th-sort{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.produits-th-sort:hover{color:var(--text)}.produits-th-sort__inner{display:inline-flex;align-items:center;gap:5px}.produits-th-sort__icon{display:flex;align-items:center;color:var(--muted);opacity:.5;transition:opacity .15s ease,color .15s ease}.produits-th-sort:hover .produits-th-sort__icon{opacity:1}.produits-th-sort--active .produits-th-sort__icon{color:var(--accent);opacity:1}.produits-table-wrapper{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 3px #0000000f,0 4px 16px #0000000a;overflow:auto}.produits-table{width:100%;border-collapse:collapse;font-size:13px;white-space:nowrap}.produits-table thead tr{background:var(--card-bg)}.produits-table th{padding:11px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card-bg);z-index:1;white-space:nowrap}.produits-table th.col-num,.produits-table td.col-num{text-align:right}.produits-table tbody tr{transition:background .12s ease;cursor:default}.produits-table tbody tr:nth-child(2n) td{background:#00000003}.produits-table tbody tr:hover td{background:var(--accent-light)!important}.produits-table td{padding:8px 14px;color:var(--text);border-bottom:1px solid var(--border);max-width:160px;overflow:hidden;text-overflow:ellipsis;vertical-align:middle}.produits-table tr:last-child td{border-bottom:none}.produits-table__th-check,.produits-table__td-check{width:40px;padding:8px 0 8px 14px}.produits-checkbox{width:15px;height:15px;cursor:pointer;accent-color:var(--accent);border-radius:4px}.produits-row--selected td{background:var(--accent-light)!important}.produits-table__th-photo,.produits-table__td-photo{width:68px;padding:6px 8px 6px 14px}.produits-photo-thumb{width:52px;height:52px;object-fit:cover;border-radius:9px;border:1px solid var(--border);display:block;box-shadow:0 1px 3px #00000014}@keyframes produits-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.produits-photo-skeleton{background:linear-gradient(90deg,var(--border) 25%,rgba(0,0,0,.06) 50%,var(--border) 75%);background-size:200% 100%;animation:produits-shimmer 1.4s ease infinite;border:none!important;opacity:1!important}.produits-photo-skeleton--modal{width:110px;height:110px;border-radius:10px}.produits-row--skeleton td{pointer-events:none}.produits-cell-skeleton{height:13px;border-radius:6px;background:linear-gradient(90deg,var(--border) 25%,rgba(0,0,0,.05) 50%,var(--border) 75%);background-size:200% 100%;animation:produits-shimmer 1.4s ease infinite;min-width:24px}.produits-photo-thumb--clickable,.produits-photo-placeholder--clickable{cursor:pointer;transition:opacity .15s ease,transform .15s ease}.produits-photo-thumb--clickable:hover{opacity:.82;transform:scale(1.04)}.produits-photo-placeholder--clickable:hover{opacity:.7}.produits-photo-placeholder{width:52px;height:52px;border-radius:9px;border:1px dashed var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);background:#00000005;opacity:.5}.produits-table td.col-nom{font-weight:600;color:var(--text);max-width:200px}.badge-categorie{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:500;background:rgba(var(--accent-rgb, 230, 100, 50),.08);color:var(--accent);border:1px solid rgba(var(--accent-rgb, 230, 100, 50),.15);white-space:nowrap}.badge-ecopart-categorie{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:500;background:#6366f114;color:#6366f1;border:1px solid rgba(99,102,241,.15);white-space:nowrap}.produits-link{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:6px;font-size:12px;font-weight:500;color:var(--accent);background:var(--accent-light);border:1px solid rgba(var(--accent-rgb, 230, 100, 50),.2);text-decoration:none;transition:background .12s ease,border-color .12s ease;white-space:nowrap}.produits-link:hover{background:rgba(var(--accent-rgb, 230, 100, 50),.15);border-color:var(--accent)}.produits-link--ebay,.produits-link--cdiscount{width:92px;justify-content:center}.produits-link--ebay{color:#0064d2;background:#eff6ff;border-color:#bfdbfe}.produits-link--ebay:hover{background:#dbeafe;border-color:#93c5fd}.produits-link--cdiscount{color:#dc2626;background:#fff1f1;border-color:#fecaca}.produits-link--cdiscount:hover{background:#fee2e2;border-color:#f87171}.produits-table td.col-price{font-variant-numeric:tabular-nums;color:var(--text);text-align:right;font-size:12.5px}.produits-table td.col-computed{font-variant-numeric:tabular-nums;text-align:right;font-size:12.5px}.col-benefice--pos{color:#16a34a;font-weight:600}.col-benefice--neg{color:#dc2626;font-weight:600}.col-benefice--zero{color:var(--muted)}.col-prix-min{color:var(--text);font-weight:500}.badge-vendre{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.01em}.badge-vendre--oui{background:#dcfce7;color:#16a34a;border:1px solid #bbf7d0}.badge-vendre--non{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.badge-urssaf{display:inline-block;padding:2px 7px;border-radius:6px;font-size:11px;font-weight:500;background:#f59e0b14;color:#b45309;border:1px solid rgba(245,158,11,.2);font-variant-numeric:tabular-nums}.produits-table__actions{display:flex;gap:4px;align-items:center;justify-content:flex-end;opacity:0;transition:opacity .15s ease}.produits-table tr:hover .produits-table__actions{opacity:1}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;border:1px solid var(--border);background:var(--card-bg);color:var(--muted);cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease;flex-shrink:0}.btn-icon:hover{background:var(--accent-light);color:var(--accent);border-color:rgba(var(--accent-rgb, 230, 100, 50),.35)}.produits-empty{text-align:center;padding:72px var(--space-4);color:var(--muted);font-size:var(--text-sm);display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.produits-empty__icon{width:56px;height:56px;border-radius:14px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:var(--space-2)}.produits-empty__title{font-size:15px;font-weight:600;color:var(--text)}.produits-empty__sub{font-size:13px;color:var(--muted)}.produits-error{padding:10px 14px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:var(--text-sm);margin-bottom:var(--space-4)}.produits-modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.produits-modal{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 64px #00000024,0 4px 16px #0000000f;width:100%;max-width:700px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.produits-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 16px;border-bottom:1px solid var(--border)}.produits-modal__title{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.01em}.produits-modal__body{padding:22px;display:flex;flex-direction:column;gap:22px}.produits-modal__top{display:flex;gap:16px;align-items:flex-start}.produits-modal__top .produits-photo-upload{flex-shrink:0;align-self:stretch}.produits-modal__top .produits-photo-zone{width:110px;height:100%;flex-direction:column;gap:6px;font-size:11px;justify-content:center;padding:0}.produits-modal__top .produits-photo-preview{height:100%}.produits-modal__top .produits-photo-preview img{width:110px;height:100%;object-fit:cover}.produits-modal__top-fields{flex:1;display:flex;flex-direction:column;gap:12px;min-width:0}.produits-modal__row{display:flex;gap:12px;flex-wrap:wrap}.produits-modal__row .field{flex:1;min-width:110px}.produits-modal__section{display:flex;flex-direction:column;gap:12px}.produits-modal__section-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding-bottom:8px;border-bottom:1px solid var(--border)}.produits-modal__footer{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 22px;border-top:1px solid var(--border)}.produits-modal__footer-right{display:flex;gap:10px;align-items:center}.btn-danger{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;background:#fee2e2;color:#dc2626;border:1px solid #fecaca;border-radius:8px;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .15s ease,border-color .15s ease}.field input,.field select{padding:8px 11px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);transition:border-color .15s ease,box-shadow .15s ease;outline:none}.field input:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.field input::placeholder{color:var(--muted);opacity:.6}.produits-photo-upload{display:flex;align-items:center;gap:var(--space-3)}.produits-photo-zone{display:flex;align-items:center;gap:8px;padding:10px 14px;border:1.5px dashed var(--border);border-radius:10px;background:#00000004;color:var(--muted);font-size:var(--text-sm);font-family:var(--font);cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease}.produits-photo-zone:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.produits-photo-preview{position:relative;display:inline-block}.produits-photo-preview img{width:72px;height:72px;object-fit:cover;border-radius:10px;border:1px solid var(--border);display:block;box-shadow:0 2px 8px #00000014}.produits-photo-remove{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:999px;border:1px solid var(--border);background:var(--card-bg);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;box-shadow:0 1px 4px #0000001a;transition:background .12s ease,color .12s ease}.produits-photo-remove:hover{background:#fee2e2;color:#dc2626;border-color:#fecaca}.btn-primary{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .15s ease,box-shadow .15s ease;box-shadow:0 1px 3px #0000001f}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 3px 8px #00000026}.btn-secondary{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.btn-secondary:hover{background:var(--accent-light);color:var(--accent);border-color:rgba(var(--accent-rgb, 230, 100, 50),.3)}.produits-row-click{cursor:pointer}.produits-row--top td{background:#eab3080a!important}.produits-row--warn td{background:#eab3080f!important}.produits-row--loss td{background:#dc26260a!important}.produits-nom-cell{display:flex;align-items:center;gap:8px;min-width:0}.produits-nom-cell__name{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;max-width:160px}.badge-perf{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.01em;white-space:nowrap;flex-shrink:0}.badge-perf--top{background:#fef9c3;color:#a16207;border:1px solid #fde047}.badge-perf--rentable{background:#dcfce7;color:#15803d;border:1px solid #86efac}.badge-perf--faible{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}.badge-perf--nonrentable{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.produits-insights{display:flex;align-items:center;gap:8px;margin-bottom:var(--space-4);flex-wrap:wrap}.produits-insights__item{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:500;border:1px solid transparent;transition:opacity .15s,transform .15s}.produits-insights__item--top{background:#fef9c3;color:#a16207;border-color:#fde047;cursor:pointer}.produits-insights__item--top:hover{opacity:.8}.produits-insights__item--warn{background:#fee2e2;color:#dc2626;border-color:#fecaca;cursor:pointer}.produits-insights__item--warn:hover{opacity:.8}.produits-insights__item--muted{background:var(--card-bg);color:var(--muted);border-color:var(--border)}.produits-insights__item--count{background:var(--card-bg);color:var(--muted);border-color:var(--border);margin-left:auto}.produits-filters{display:flex;align-items:center;gap:8px;margin-bottom:var(--space-4);flex-wrap:wrap}.produits-filters__search{position:relative;display:flex;align-items:center;flex:1;min-width:200px;max-width:280px}.produits-filters__search-icon{position:absolute;left:10px;color:var(--muted);pointer-events:none}.produits-filters__search-input{width:100%;height:36px;padding:0 32px 0 30px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);outline:none;transition:border-color .15s,box-shadow .15s}.produits-filters__search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.produits-filters__search-input::placeholder{color:var(--muted);opacity:.7}.produits-filters__clear-btn{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:var(--muted);display:flex;align-items:center;padding:2px}.produits-filters__clear-btn:hover{color:var(--text)}.produits-filters__select{height:36px;padding:0 10px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);outline:none;cursor:pointer;transition:border-color .15s;flex:0 0 auto}.produits-filters__select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.produits-filters__toggle{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;white-space:nowrap;padding:0 4px}.produits-filters__toggle input{accent-color:var(--accent);cursor:pointer}.produits-filters__toggle:hover{color:var(--text)}.produits-filters__reset{display:inline-flex;align-items:center;gap:5px;padding:0 12px;height:36px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--muted);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.produits-filters__reset:hover{background:#fee2e2;color:#dc2626;border-color:#fecaca}.produits-pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--border);background:var(--card-bg);border-radius:0 0 12px 12px;gap:var(--space-3);flex-wrap:wrap}.produits-pagination__info{font-size:12px;color:var(--muted);min-width:120px}.produits-pagination__controls{display:flex;align-items:center;gap:4px}.produits-pagination__page{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--muted);font-size:13px;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s}.produits-pagination__page:hover{background:var(--accent-light);color:var(--accent)}.produits-pagination__page--active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.produits-pagination__size{display:flex;align-items:center;gap:4px;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:3px}.produits-pagination__size-btn{padding:3px 10px;border-radius:5px;border:none;background:transparent;color:var(--muted);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s}.produits-pagination__size-btn:hover{color:var(--text)}.produits-pagination__size-btn--active{background:var(--accent);color:#fff;font-weight:600}.pd-overlay{position:fixed;inset:0;background:#00000059;z-index:300;animation:pd-fade-in .2s ease}@keyframes pd-fade-in{0%{opacity:0}to{opacity:1}}.pd-drawer{position:fixed;top:0;right:0;bottom:0;width:440px;max-width:95vw;background:var(--card-bg);border-left:1px solid var(--border);box-shadow:-8px 0 40px #0000001f;z-index:301;overflow-y:auto;display:flex;flex-direction:column;animation:pd-slide-in .25s cubic-bezier(.32,.72,0,1)}@keyframes pd-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.pd-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--border);gap:12px;position:sticky;top:0;background:var(--card-bg);z-index:1}.pd-header__left{display:flex;align-items:center;gap:12px;min-width:0}.pd-header__img{width:52px;height:52px;border-radius:10px;object-fit:cover;border:1px solid var(--border);flex-shrink:0}.pd-header__img-placeholder{width:52px;height:52px;border-radius:10px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;color:var(--accent);border:1px dashed var(--border);flex-shrink:0}.pd-header__name{font-size:15px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pd-header__meta{display:flex;align-items:center;flex-wrap:wrap;gap:4px;margin-top:4px}.pd-header__actions{display:flex;gap:6px;flex-shrink:0}.pd-kpis{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border);border-bottom:1px solid var(--border)}.pd-kpi{background:var(--card-bg);padding:14px 16px;display:flex;flex-direction:column;gap:4px}.pd-kpi__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}.pd-kpi__value{font-size:15px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.pd-value--pos{color:#16a34a}.pd-value--neg{color:#dc2626}.pd-section{padding:18px 20px;border-bottom:1px solid var(--border)}.pd-section:last-child{border-bottom:none}.pd-section__title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px}.pd-bar-chart{height:14px;border-radius:7px;overflow:hidden;display:flex;background:var(--border);margin-bottom:8px}.pd-bar-chart__seg{height:100%;transition:width .5s ease}.pd-bar-chart__seg--cost{background:#60a5fa}.pd-bar-chart__seg--fees{background:#fbbf24}.pd-bar-chart__seg--ben{background:#4ade80}.pd-bar-legend{display:flex;gap:12px}.pd-bar-legend__item{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px}.pd-bar-legend__item:before{content:"";width:8px;height:8px;border-radius:50%;flex-shrink:0}.pd-bar-legend__item--cost:before{background:#60a5fa}.pd-bar-legend__item--fees:before{background:#fbbf24}.pd-bar-legend__item--ben:before{background:#4ade80}.pd-rows{display:flex;flex-direction:column;gap:10px}.pd-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.pd-row__label{font-size:12px;color:var(--muted);flex-shrink:0}.pd-row__value{font-size:13px;color:var(--text);font-weight:500;text-align:right}.pd-row__value.mono{font-family:monospace;font-size:12px}.pd-links{display:flex;gap:8px;flex-wrap:wrap}.import-dropzone{border:2px dashed var(--border);border-radius:10px;padding:32px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}.import-dropzone:hover,.import-dropzone--over{border-color:var(--accent);background:rgba(var(--accent-rgb, 230, 100, 50),.04)}.import-bulk{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.import-bulk__field{display:flex;flex-direction:column;gap:4px;flex:1;min-width:160px}.import-bulk__field label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--muted);letter-spacing:.03em}.import-bulk__field select{padding:6px 8px;border-radius:6px;border:1px solid var(--border);font-size:13px;background:var(--bg);color:var(--text)}.import-summary{font-size:13px;color:var(--muted);margin-bottom:8px;font-weight:500}.import-table-wrapper{max-height:380px;overflow-y:auto;border:1px solid var(--border);border-radius:8px}.import-table{width:100%;border-collapse:collapse;font-size:12px}.import-table th{position:sticky;top:0;background:var(--bg-card);padding:6px 8px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}.import-table td{padding:5px 8px;border-bottom:1px solid var(--border-light, rgba(0,0,0,.05));color:var(--text)}.import-table tr:last-child td{border-bottom:none}.import-row--disabled{opacity:.4}.import-cell-nom{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-cell-num{font-family:monospace;font-size:12px;white-space:nowrap}.import-cell-photo{width:36px;text-align:center}.import-photo-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px dashed var(--border);cursor:pointer;color:var(--muted);transition:border-color .15s,color .15s}.import-photo-btn:hover{border-color:var(--accent);color:var(--accent)}.import-photo-thumb{width:30px;height:30px;border-radius:6px;object-fit:cover}.import-progress{margin-top:12px;font-size:13px;color:var(--muted)}.import-progress__bar{margin-top:6px;height:6px;border-radius:3px;background:var(--border);overflow:hidden}.import-progress__fill{height:100%;border-radius:3px;background:var(--accent);transition:width .2s}.badge-en-vente{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:11px;font-weight:600;white-space:nowrap}.badge-en-vente--oui{background:#dcfce7;color:#16a34a}.badge-en-vente--non{background:#f3f4f6;color:#6b7280}.produits-toggle-label{display:inline-flex;align-items:center;gap:var(--space-3);cursor:pointer;-webkit-user-select:none;user-select:none}.produits-toggle-label__text{font-size:var(--text-sm);font-weight:500;color:var(--text)}.produits-toggle{width:44px;height:24px;border-radius:99px;background:var(--border);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}.produits-toggle--on{background:#16a34a}.produits-toggle__thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s cubic-bezier(.34,1.56,.64,1)}.produits-toggle--on .produits-toggle__thumb{transform:translate(20px)}.ventes-page{padding:var(--space-6);max-width:1400px}.ventes-header{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-5)}.ventes-header__top{display:flex;align-items:center;justify-content:space-between}.ventes-header__title{font-size:1.25rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.ventes-header__bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.ventes-header__imports{display:flex;gap:var(--space-2);align-items:center}.ventes-periods{display:flex;gap:4px;background:var(--card-bg);border:1px solid var(--border);border-radius:9px;padding:3px}.ventes-period-btn{padding:5px 12px;border-radius:6px;border:none;background:transparent;color:var(--muted);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .15s ease,color .15s ease;white-space:nowrap}.ventes-period-btn:hover{background:#0000000a;color:var(--text)}.ventes-period-btn--active{background:var(--accent);color:#fff;font-weight:600}.ventes-period-btn--active:hover{background:var(--accent-hover)}.ventes-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-4);margin-bottom:var(--space-5)}.ventes-kpi{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:16px 20px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;gap:4px}.ventes-kpi__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.ventes-kpi__value{font-size:1.5rem;font-weight:700;color:var(--text);letter-spacing:-.02em;font-variant-numeric:tabular-nums}.ventes-kpi__value--pos{color:#16a34a}.ventes-kpi__value--neg{color:#dc2626}.ventes-kpi__sub{font-size:11px;color:var(--muted)}.ventes-kpi__sub--breakdown{font-variant-numeric:tabular-nums}.ventes-table-wrapper{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 3px #0000000f,0 4px 16px #0000000a;overflow:auto}.ventes-table{width:100%;border-collapse:collapse;font-size:13px;white-space:nowrap}.ventes-table th{padding:11px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--card-bg);position:sticky;top:0;z-index:1;white-space:nowrap}.ventes-table th.col-r{text-align:right}.ventes-table td{padding:11px 14px;color:var(--text);border-bottom:1px solid var(--border);vertical-align:middle}.ventes-table tr:last-child td{border-bottom:none}.ventes-table tbody tr:nth-child(2n) td{background:#00000003}.ventes-table tbody tr:hover td{background:var(--accent-light)!important}.ventes-produit-cell{display:flex;align-items:center;gap:10px}.ventes-produit-img{width:36px;height:36px;border-radius:8px;object-fit:cover;border:1px solid var(--border);flex-shrink:0}.ventes-produit-placeholder{width:36px;height:36px;border-radius:8px;border:1px dashed var(--border);background:#00000005;display:flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0;opacity:.5}.ventes-produit-name{font-weight:600;color:var(--text);max-width:180px;overflow:hidden;text-overflow:ellipsis}.ventes-table td.col-r{text-align:right;font-variant-numeric:tabular-nums}.ventes-ca{font-weight:600;color:var(--text)}.ventes-ben--pos{font-weight:600;color:#16a34a}.ventes-ben--neg{font-weight:600;color:#dc2626}.ventes-ben--zero{color:var(--muted)}.ventes-table__actions{display:flex;gap:4px;justify-content:flex-end;opacity:0;transition:opacity .15s ease}.ventes-table tr:hover .ventes-table__actions{opacity:1}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;border:1px solid var(--border);background:var(--card-bg);color:var(--muted);cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.btn-icon:hover{background:var(--accent-light);color:var(--accent);border-color:#e6643259}.btn-icon--danger:hover{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ventes-empty{text-align:center;padding:72px var(--space-4);display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.ventes-empty__icon{width:56px;height:56px;border-radius:14px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:var(--space-2)}.ventes-empty__title{font-size:15px;font-weight:600;color:var(--text)}.ventes-empty__sub{font-size:13px;color:var(--muted)}.ventes-error{padding:10px 14px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:var(--text-sm);margin-bottom:var(--space-4)}.vente-modal-overlay{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}.vente-modal{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;box-shadow:0 32px 80px #0000002e,0 4px 16px #0000000f;width:100%;max-width:680px;max-height:94vh;overflow-y:auto;display:flex;flex-direction:column}.vente-modal__header{display:flex;align-items:center;justify-content:space-between;padding:22px 28px 18px;border-bottom:1px solid var(--border)}.vente-modal__title{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.02em}.vente-modal__body{padding:24px 28px;display:flex;flex-direction:column;gap:20px}.vente-modal__footer{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 28px;border-top:1px solid var(--border)}.vente-modal__footer-right{display:flex;gap:8px;align-items:center}.vm-block{display:flex;flex-direction:column;gap:10px}.vm-block__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--muted)}.vm-produit-row{display:flex;gap:10px;align-items:stretch}.vm-produit-select{flex:1;min-width:0}.vm-select-sm,.vm-input-sm{height:40px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);outline:none;transition:border-color .15s,box-shadow .15s;white-space:nowrap}.vm-select-sm{flex:0 0 120px;cursor:pointer}.vm-input-sm{flex:0 0 140px}.vm-select-sm:focus,.vm-input-sm:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.vm-select-sm option{color:var(--text)}.vm-numbers-grid{display:grid;grid-template-columns:80px 1fr 1fr;gap:10px;align-items:end}.vm-num-field{display:flex;flex-direction:column;gap:6px}.vm-num-field--main .vm-num-field__input{font-size:15px;font-weight:600}.vm-num-field__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);white-space:nowrap}.vm-num-field__label-row{display:flex;align-items:center;gap:6px}.vm-num-field__input{height:40px;padding:0 12px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);font-variant-numeric:tabular-nums;outline:none;transition:border-color .15s,box-shadow .15s;width:100%;box-sizing:border-box}.vm-num-field__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.vm-num-field__input::placeholder{color:var(--muted);opacity:.5}.vm-result{display:flex;align-items:center;gap:0;background:#f8fafc;border:1.5px solid var(--border);border-radius:12px;padding:16px 20px;transition:border-color .2s,background .2s}.vm-result--pos{background:#f0fdf4;border-color:#86efac}.vm-result--neg{background:#fff5f5;border-color:#fca5a5}.vm-result__item{display:flex;flex-direction:column;gap:3px;flex:1}.vm-result__item--benefice{flex:0 0 auto;min-width:160px}.vm-result__divider{width:1px;height:36px;background:var(--border);margin:0 20px;flex-shrink:0}.vm-result__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.vm-result__value{font-size:14px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.vm-result__value--big{font-size:26px;font-weight:800;letter-spacing:-.02em}.vm-result--pos .vm-result__item--benefice .vm-result__value{color:#16a34a}.vm-result--neg .vm-result__item--benefice .vm-result__value{color:#dc2626}.vm-secondary-row{display:flex;gap:10px}.field{display:flex;flex-direction:column;gap:5px}.field label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.field input,.field select,.field textarea{padding:8px 11px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);transition:border-color .15s ease,box-shadow .15s ease;outline:none}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.field input::placeholder,.field textarea::placeholder{color:var(--muted);opacity:.6}.field textarea{resize:vertical;min-height:64px}.btn-primary{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .15s ease;white-space:nowrap}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .15s ease,color .15s ease;white-space:nowrap}.btn-secondary:hover{background:var(--accent-light);color:var(--accent)}.btn-danger{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;background:#fee2e2;color:#dc2626;border:1px solid #fecaca;border-radius:8px;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .15s ease;white-space:nowrap}.btn-danger:hover{background:#fecaca;border-color:#f87171}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.produit-select{position:relative;width:100%}.produit-select__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 10px;height:36px;background:var(--input-bg, var(--card-bg));border:1px solid var(--border);border-radius:8px;cursor:pointer;text-align:left;transition:border-color .15s}.produit-select__trigger:hover{border-color:var(--accent)}.produit-select__trigger--open{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb, 234 88 12) / .12)}.produit-select__placeholder{color:var(--muted);font-size:13px}.produit-select__chevron{flex-shrink:0;color:var(--muted);transition:transform .15s}.produit-select__trigger--open .produit-select__chevron{transform:rotate(180deg)}.produit-select__dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:9999;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #0000001f;overflow:hidden}.produit-select__search{display:flex;align-items:center;gap:6px;padding:8px 10px;border-bottom:1px solid var(--border)}.produit-select__search-icon{color:var(--muted);flex-shrink:0}.produit-select__search-input{flex:1;border:none;background:transparent;font-size:13px;color:var(--text);outline:none}.produit-select__search-clear{background:none;border:none;cursor:pointer;color:var(--muted);padding:2px;display:flex;align-items:center}.produit-select__search-clear:hover{color:var(--text)}.produit-select__list{max-height:240px;overflow-y:auto;padding:4px}.produit-select__empty{padding:16px;text-align:center;color:var(--muted);font-size:13px}.produit-select__option{width:100%;display:flex;background:none;border:none;border-radius:6px;padding:6px 8px;cursor:pointer;text-align:left;transition:background .1s}.produit-select__option:hover,.produit-select__option--active{background:var(--accent-light, #fff7ed)}.produit-select-item{display:flex;align-items:center;gap:10px;min-width:0}.produit-select-item--compact{gap:7px}.produit-select-item__img{width:32px;height:32px;border-radius:6px;background:var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;color:var(--muted)}.produit-select-item--compact .produit-select-item__img{width:24px;height:24px;border-radius:4px}.produit-select-item__img img{width:100%;height:100%;object-fit:cover}.produit-select-item__info{display:flex;flex-direction:column;min-width:0}.produit-select-item__nom{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.produit-select-item__id{font-size:11px;color:var(--muted);font-family:monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vente-cost-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.vente-cost-header label{margin-bottom:0;white-space:nowrap;flex-shrink:0}.vente-cost-toggle{display:inline-flex;background:var(--border);border-radius:6px;padding:2px;gap:2px}.vente-cost-toggle__btn{padding:2px 8px;font-size:11px;font-weight:500;border:none;border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.vente-cost-toggle__btn:hover{color:var(--text)}.vente-cost-toggle__btn--active{background:var(--card-bg);color:var(--accent);box-shadow:0 1px 2px #00000014}.ventes-th-sort{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.ventes-th-sort:hover{color:var(--text)}.ventes-th-sort--active{color:var(--text)!important}.ventes-row--active td{background:var(--accent-light)!important}.ventes-insights{display:flex;align-items:center;gap:0;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:10px 16px;margin-bottom:var(--space-4);font-size:13px;color:var(--text);flex-wrap:wrap;gap:6px}.ventes-insights__icon{color:var(--accent);flex-shrink:0}.ventes-insights__item{display:flex;align-items:center;gap:6px}.ventes-insights__item--sep{padding-left:14px;border-left:1px solid var(--border);margin-left:8px}.ventes-insights__item--muted{color:var(--muted)}.ventes-filters{display:flex;align-items:center;gap:8px;margin-bottom:var(--space-4);flex-wrap:wrap}.ventes-filters__search{position:relative;display:flex;align-items:center;flex:1;min-width:200px;max-width:320px}.ventes-filters__search-icon{position:absolute;left:10px;color:var(--muted);pointer-events:none}.ventes-filters__search-input{width:100%;height:36px;padding:0 32px 0 30px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);outline:none;transition:border-color .15s,box-shadow .15s}.ventes-filters__search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.ventes-filters__search-input::placeholder{color:var(--muted);opacity:.7}.ventes-filters__clear-btn{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:var(--muted);display:flex;align-items:center;padding:2px}.ventes-filters__clear-btn:hover{color:var(--text)}.ventes-filters__select,.ventes-filters__date{height:36px;padding:0 10px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);outline:none;cursor:pointer;transition:border-color .15s}.ventes-filters__select:focus,.ventes-filters__date:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.ventes-filters__date{flex:0 0 140px}.ventes-filters__select{flex:0 0 auto}.ventes-filters__date-sep{color:var(--muted);font-size:13px;flex-shrink:0}.ventes-filters__reset{display:inline-flex;align-items:center;gap:5px;padding:0 12px;height:36px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--muted);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.ventes-filters__reset:hover{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ventes-pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--border);background:var(--card-bg);border-radius:0 0 12px 12px;gap:var(--space-3);flex-wrap:wrap}.ventes-pagination__info{font-size:12px;color:var(--muted);min-width:120px}.ventes-pagination__controls{display:flex;align-items:center;gap:4px}.ventes-pagination__page{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--muted);font-size:13px;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s,border-color .12s}.ventes-pagination__page:hover{background:var(--accent-light);color:var(--accent)}.ventes-pagination__page--active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.ventes-pagination__ellipsis{color:var(--muted);font-size:13px;padding:0 2px}.ventes-pagination__size{display:flex;align-items:center;gap:4px;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:3px}.ventes-pagination__size-btn{padding:3px 10px;border-radius:5px;border:none;background:transparent;color:var(--muted);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s}.ventes-pagination__size-btn:hover{color:var(--text)}.ventes-pagination__size-btn--active{background:var(--accent);color:#fff;font-weight:600}.vd-overlay{position:fixed;inset:0;background:#00000059;z-index:300;animation:vd-fade-in .2s ease}@keyframes vd-fade-in{0%{opacity:0}to{opacity:1}}.vd-drawer{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:95vw;background:var(--card-bg);border-left:1px solid var(--border);box-shadow:-8px 0 40px #0000001f;z-index:301;overflow-y:auto;display:flex;flex-direction:column;animation:vd-slide-in .25s cubic-bezier(.32,.72,0,1)}@keyframes vd-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.vd-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--border);gap:12px;position:sticky;top:0;background:var(--card-bg);z-index:1}.vd-header__left{display:flex;align-items:center;gap:12px;min-width:0}.vd-header__img{width:44px;height:44px;border-radius:10px;object-fit:cover;border:1px solid var(--border);flex-shrink:0}.vd-header__img-placeholder{width:44px;height:44px;border-radius:10px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;color:var(--accent);border:1px dashed var(--border);flex-shrink:0}.vd-header__name{font-size:14px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vd-header__meta{font-size:12px;color:var(--muted);margin-top:2px;display:flex;align-items:center}.vd-header__actions{display:flex;gap:6px;flex-shrink:0}.vd-kpis{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border);border-bottom:1px solid var(--border)}.vd-kpi{background:var(--card-bg);padding:14px 16px;display:flex;flex-direction:column;gap:4px}.vd-kpi__label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}.vd-kpi__value{font-size:15px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.vd-value--pos{color:#16a34a}.vd-value--neg{color:#dc2626}.vd-section{padding:18px 20px;border-bottom:1px solid var(--border)}.vd-section:last-child{border-bottom:none}.vd-section__title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:12px}.vd-rows{display:flex;flex-direction:column;gap:10px}.vd-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.vd-row__label{font-size:12px;color:var(--muted);flex-shrink:0}.vd-row__value{font-size:13px;color:var(--text);font-weight:500;text-align:right}.ebay-overlay{position:fixed;inset:0;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.ebay-modal{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:860px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.ebay-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);flex-shrink:0}.ebay-modal__title{font-size:var(--text-base);font-weight:600;color:var(--text)}.ebay-modal__close{background:none;border:none;cursor:pointer;color:var(--muted);display:flex;align-items:center;padding:4px;border-radius:var(--radius);transition:color .15s,background .15s}.ebay-modal__close:hover{color:var(--text);background:var(--bg-hover)}.ebay-modal__body{padding:var(--space-5);overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:var(--space-4)}.ebay-modal__body--done{align-items:center;justify-content:center;text-align:center;gap:var(--space-3)}.ebay-dropzone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-5);display:flex;flex-direction:column;align-items:center;gap:var(--space-2);cursor:pointer;transition:border-color .2s,background .2s}.ebay-dropzone:hover,.ebay-dropzone--over{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,transparent)}.ebay-dropzone__icon{color:var(--muted)}.ebay-dropzone--over .ebay-dropzone__icon{color:var(--accent)}.ebay-dropzone__text{font-size:var(--text-sm);font-weight:500;color:var(--text)}.ebay-dropzone__sub{font-size:var(--text-xs);color:var(--muted)}.ebay-error{display:flex;align-items:center;gap:6px;font-size:var(--text-sm);color:#ef4444;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius);padding:8px 12px}.ebay-help{font-size:var(--text-xs);color:var(--muted);line-height:1.5}.ebay-summary{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.ebay-summary__item{display:flex;align-items:center;gap:5px;font-size:var(--text-xs);font-weight:500;padding:4px 10px;border-radius:99px}.ebay-summary__item--ok{background:#22c55e1f;color:#16a34a}.ebay-summary__item--dup{background:var(--bg-secondary);color:var(--muted)}.ebay-summary__item--warn{background:#f59e0b1f;color:#d97706}.ebay-preview-wrapper{overflow-x:auto;overflow-y:auto;max-height:340px;border:1px solid var(--border);border-radius:var(--radius)}.ebay-preview-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.ebay-preview-table thead th{background-color:var(--card-bg);color:var(--muted);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:8px 12px;text-align:left;position:sticky;top:0;z-index:2;box-shadow:0 1px 0 var(--border)}.ebay-preview-table tbody tr{border-top:1px solid var(--border);transition:background .1s}.ebay-preview-table tbody tr:hover{background:var(--bg-hover)}.ebay-preview-table td{padding:8px 12px;vertical-align:middle}.ebay-row--dup{opacity:.5}.ebay-status-cell{width:60px}.ebay-icon--ok{color:#22c55e}.ebay-icon--warn{color:#f59e0b}.ebay-badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:99px}.ebay-badge--dup{background:var(--bg-secondary);color:var(--muted)}.ebay-title-cell{max-width:220px}.ebay-ref-cell{font-family:monospace;font-size:12px;color:var(--muted)}.ebay-produit-select{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:12px;padding:4px 8px;cursor:pointer;max-width:200px}.ebay-produit-select:focus{outline:none;border-color:var(--accent)}.ebay-dup-label{font-size:12px;color:var(--muted);font-style:italic}.ebay-modal__footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border);margin-top:auto}.ebay-done__icon{color:#22c55e}.ebay-done__title{font-size:var(--text-lg);font-weight:600;color:var(--text)}.ebay-done__sub{font-size:var(--text-sm);color:var(--muted)}.an-page{padding:var(--space-6);max-width:1400px;display:flex;flex-direction:column;gap:var(--space-6)}.an-loading{padding:var(--space-10);text-align:center;color:var(--muted);font-size:var(--text-sm)}.an-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4)}.an-header__title{font-size:var(--text-2xl);font-weight:700;color:var(--text);margin:0 0 2px}.an-header__sub{font-size:var(--text-sm);color:var(--muted);margin:0}.an-summary{display:flex;align-items:flex-start;gap:var(--space-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);line-height:1.65;animation:an-fade-in .3s ease both}.an-summary__icon{font-size:18px;flex-shrink:0;margin-top:1px}.an-summary__text{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.an-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-4)}@media(max-width:1100px){.an-kpis{grid-template-columns:repeat(3,1fr)}}@media(max-width:700px){.an-kpis{grid-template-columns:repeat(2,1fr)}}.an-kpi{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-sm);transition:box-shadow .18s ease,transform .18s ease;cursor:default}.an-kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.an-kpi__label{font-size:var(--text-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500;display:flex;align-items:center;gap:5px}.an-kpi__tooltip-wrap{position:relative;display:inline-flex;align-items:center}.an-kpi__tooltip-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:var(--border);color:var(--muted);font-size:9px;font-weight:700;cursor:default;flex-shrink:0;text-transform:none;letter-spacing:0;line-height:1}.an-kpi__tooltip-bubble{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--text);color:var(--card-bg);font-size:11px;font-weight:400;line-height:1.45;padding:6px 10px;border-radius:var(--radius);white-space:normal;width:200px;text-align:center;text-transform:none;letter-spacing:0;pointer-events:none;opacity:0;transition:opacity .15s ease;z-index:50;box-shadow:var(--shadow-md)}.an-kpi__tooltip-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--text)}.an-kpi__tooltip-wrap:hover .an-kpi__tooltip-bubble{opacity:1}.an-kpi__value{font-size:var(--text-2xl);font-weight:700;color:var(--text);line-height:1.1}.an-kpi__spark{margin-top:2px;margin-bottom:2px;height:36px;opacity:.65;transition:opacity .18s}.an-kpi:hover .an-kpi__spark{opacity:1}.an-kpi__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-top:2px}.an-kpi__sub{font-size:var(--text-xs);color:var(--muted)}.an-kpi__evo{display:inline-flex;align-items:center;gap:2px;font-size:var(--text-xs);font-weight:600;border-radius:999px;padding:2px 6px}.kpi-evo--pos{background:#dcfce7;color:#15803d}.kpi-evo--neg{background:#fee2e2;color:#b91c1c}.kpi-evo--zero{background:var(--surface);color:var(--muted)}.an-insights{display:flex;flex-direction:column;gap:var(--space-2)}.an-insight{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius);border:1px solid transparent;font-size:var(--text-sm);animation:an-slide-in .2s ease both}.an-insight:nth-child(1){animation-delay:0ms}.an-insight:nth-child(2){animation-delay:40ms}.an-insight:nth-child(3){animation-delay:80ms}.an-insight:nth-child(4){animation-delay:.12s}.an-insight:nth-child(5){animation-delay:.16s}@keyframes an-slide-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes an-fade-in{0%{opacity:0}to{opacity:1}}.an-insight__icon{font-size:16px;flex-shrink:0;margin-top:1px}.an-insight__title{font-weight:600;color:var(--text);margin-bottom:2px}.an-insight__body{color:var(--text-secondary);font-size:var(--text-xs);line-height:1.5}.an-insight--success{background:#f0fdf4;border-color:#bbf7d0}.an-insight--warning{background:#fffbeb;border-color:#fde68a}.an-insight--danger{background:#fff1f2;border-color:#fecdd3}.an-insight--info{background:#eff6ff;border-color:#bfdbfe}.an-charts{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.an-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);transition:box-shadow .18s ease}.an-card:hover{box-shadow:var(--shadow-md)}.an-card--wide{grid-column:1 / -1}.an-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);gap:var(--space-3)}.an-card__title{font-size:var(--text-sm);font-weight:600;color:var(--text)}.an-card__sub{font-size:var(--text-xs);color:var(--muted)}.an-toggle{display:flex;background:var(--card-bg-alt, #f4f4f5);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px;gap:2px;flex-shrink:0}.an-toggle__btn{padding:3px 10px;font-size:var(--text-xs);font-weight:500;font-family:var(--font);border:none;border-radius:calc(var(--radius-sm) - 2px);background:transparent;color:var(--muted);cursor:pointer;transition:background var(--transition),color var(--transition);white-space:nowrap}.an-toggle__btn:hover{color:var(--text-secondary)}.an-toggle__btn--active{background:var(--card-bg);color:var(--text);box-shadow:0 1px 3px #00000014}.an-granularity{display:flex;gap:2px;background:var(--surface);border-radius:var(--radius);padding:3px}.an-gran-btn{background:transparent;border:none;cursor:pointer;font-size:var(--text-xs);font-weight:500;color:var(--muted);padding:3px 10px;border-radius:calc(var(--radius) - 2px);transition:background .12s,color .12s}.an-gran-btn:hover{color:var(--text)}.an-gran-btn--active{background:var(--card-bg);color:var(--text);box-shadow:0 1px 3px #00000014}.an-tooltip{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;box-shadow:var(--shadow-md);font-size:var(--text-xs)}.an-tooltip__label{color:var(--muted);margin-bottom:4px;font-weight:500}.an-tooltip__row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);line-height:1.6}.an-tooltip__row strong{color:var(--text)}.an-tooltip__nb{margin-top:4px;padding-top:4px;border-top:1px solid var(--border);color:var(--muted);font-size:11px}.an-heatmap-wrap{display:flex;gap:var(--space-2)}.an-heatmap-days{display:flex;flex-direction:column;gap:3px;padding-top:2px}.an-heatmap-days span{font-size:10px;color:var(--muted);height:13px;display:flex;align-items:center;line-height:1;width:10px}.an-heatmap{display:flex;gap:3px;overflow-x:auto;position:relative}.an-heatmap__col{display:flex;flex-direction:column;gap:3px}.an-heatmap__cell{width:13px;height:13px;border-radius:3px;cursor:default;transition:opacity .1s,transform .12s ease}.an-heatmap__cell:hover{transform:scale(1.5);opacity:1!important;z-index:1}.an-heatmap__cell--0{background:var(--surface);border:1px solid var(--border)}.an-heatmap__cell--1{background:#fed7aa}.an-heatmap__cell--2{background:#fb923c}.an-heatmap__cell--3{background:#ea580c}.an-heatmap__cell--4{background:#c2410c}.an-heatmap-tooltip{position:fixed;z-index:200;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:6px 10px;font-size:var(--text-xs);box-shadow:var(--shadow-md);pointer-events:none;white-space:nowrap;animation:an-fade-in .1s ease}.an-heatmap-tooltip__date{color:var(--muted);margin-bottom:3px;font-weight:500;text-transform:capitalize}.an-heatmap-tooltip__row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);color:var(--text)}.an-heatmap-tooltip__row strong{font-weight:600}.an-heatmap-legend{display:flex;align-items:center;gap:var(--space-2);margin-top:var(--space-3);font-size:11px;color:var(--muted)}.an-heatmap-stats{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--border)}.an-heatmap-stat{font-size:var(--text-xs);padding:3px 10px;border-radius:999px}.an-heatmap-stat--best{background:#dcfce7;color:#15803d}.an-heatmap-stat--worst{background:var(--surface);color:var(--muted)}.an-canal-legend{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-3)}.an-canal-legend__item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs)}.an-canal-legend__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.an-canal-legend__name{flex:1;color:var(--text-secondary)}.an-canal-legend__val{font-weight:600;color:var(--text)}.an-table-wrap{overflow-x:auto}.an-table-header{margin-bottom:var(--space-3)}.an-search{width:260px;padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:var(--text-sm);outline:none;transition:border-color .15s}.an-search:focus{border-color:var(--accent)}.an-search::placeholder{color:var(--muted)}.an-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.an-th{padding:var(--space-2) var(--space-3);text-align:left;font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.an-th:hover{color:var(--text)}.an-th--active{color:var(--accent)}.an-th__inner{display:inline-flex;align-items:center;gap:4px}.an-tr{cursor:pointer;transition:background .1s,box-shadow .12s}.an-tr:hover,.an-tr--expanded{background:var(--surface);box-shadow:inset 3px 0 0 var(--accent)}.an-tr--top td{background:#10b9810a}.an-tr--warn td{background:#f59e0b0d}.an-tr--loss td{background:#dc26260d}.an-tr td{padding:var(--space-3);border-bottom:1px solid var(--border);color:var(--text)}.an-tr-detail td{padding:0;border-bottom:1px solid var(--border);background:var(--surface)}.an-row-detail{display:flex;gap:var(--space-6);padding:var(--space-3) var(--space-4);flex-wrap:wrap}.an-row-detail__item{display:flex;flex-direction:column;gap:2px}.an-row-detail__label{font-size:var(--text-xs);color:var(--muted)}.an-row-detail__value{font-size:var(--text-sm);font-weight:600;color:var(--text)}.an-num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.an-ben{font-weight:600}.an-ben--pos{color:#15803d}.an-ben--neg{color:#b91c1c}.an-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:var(--text-xs);font-weight:600;white-space:nowrap}.an-badge--green{background:#dcfce7;color:#15803d}.an-badge--orange{background:#fff7ed;color:#c2410c}.an-badge--red{background:#fee2e2;color:#b91c1c}.an-badge--top{background:#eff6ff;color:#1d4ed8}.an-prix-delta{margin-left:4px;font-size:11px;font-weight:500}.an-prix-delta--pos{color:#15803d}.an-prix-delta--neg{color:#b91c1c}.an-canal-badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:var(--text-xs);font-weight:600}.an-produit-cell{display:flex;align-items:center;gap:var(--space-2)}.an-produit-img{border-radius:var(--radius);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--surface);color:var(--muted);flex-shrink:0}.an-produit-name{font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.an-empty{padding:var(--space-4);text-align:center;color:var(--muted);font-size:var(--text-sm)}.an-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-16);color:var(--muted);text-align:center}.an-empty-state p{font-size:var(--text-sm);margin:0}.an-drawer-overlay{position:fixed;inset:0;background:#00000059;z-index:300;animation:an-fade-in .2s ease}.an-drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:95vw;background:var(--card-bg);border-left:1px solid var(--border);box-shadow:-8px 0 32px #0000001f;z-index:301;display:flex;flex-direction:column;gap:0;overflow-y:auto;animation:an-drawer-in .25s cubic-bezier(.32,.72,0,1)}@keyframes an-drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.an-drawer__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);padding:var(--space-5) var(--space-5) var(--space-4);border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--card-bg);z-index:1}.an-drawer__title-row{display:flex;align-items:center;gap:var(--space-3)}.an-drawer__title{font-size:var(--text-lg, 1.125rem);font-weight:700;color:var(--text);margin:0 0 2px}.an-drawer__marketplace{font-size:var(--text-xs);color:var(--muted)}.an-drawer__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--muted);cursor:pointer;flex-shrink:0;transition:background .12s,color .12s}.an-drawer__close:hover{background:var(--card-bg);color:var(--text)}.an-drawer__kpis{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border);border-bottom:1px solid var(--border)}.an-drawer__kpi{display:flex;flex-direction:column;gap:3px;padding:var(--space-4);background:var(--card-bg)}.an-drawer__kpi-label{font-size:var(--text-xs);color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.an-drawer__kpi-value{font-size:var(--text-base, 1rem);font-weight:700;color:var(--text);line-height:1.2}.an-drawer__kpi-value--pos{color:#15803d}.an-drawer__kpi-value--neg{color:#b91c1c}.an-drawer__prix-compare{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);flex-wrap:wrap}.an-drawer__prix-item{display:flex;flex-direction:column;gap:2px}.an-drawer__prix-label{font-size:var(--text-xs);color:var(--muted)}.an-drawer__prix-value{font-size:var(--text-sm);font-weight:600;color:var(--text)}.an-drawer__prix-arrow{color:var(--muted);font-size:18px;flex-shrink:0}.an-drawer__prix-delta{margin-left:auto;font-size:var(--text-xs);font-weight:700;padding:3px 10px;border-radius:999px}.an-drawer__prix-delta--pos{background:#dcfce7;color:#15803d}.an-drawer__prix-delta--neg{background:#fee2e2;color:#b91c1c}.an-drawer__chart-section{padding:var(--space-5);border-bottom:1px solid var(--border)}.an-drawer__section-title{display:block;font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-3)}.an-drawer__canal{padding:var(--space-4) var(--space-5);display:flex;align-items:center;gap:var(--space-3)}.ep-page{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}.ep-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.ep-header__left{display:flex;align-items:center;gap:14px}.ep-header__icon{width:42px;height:42px;border-radius:12px;background:#dcfce7;color:#16a34a;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid #bbf7d0}.ep-header__title{font-size:1.25rem;font-weight:700;color:var(--text);letter-spacing:-.01em}.ep-header__sub{font-size:13px;color:var(--muted);margin-top:2px}.ep-period-picker{position:relative}.ep-period-trigger{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:border-color .15s,box-shadow .15s;white-space:nowrap;box-shadow:0 1px 3px #0000000d}.ep-period-trigger:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.ep-period-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:220px;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px #0000001f;z-index:100;overflow:hidden}.ep-period-list{padding:6px;display:flex;flex-direction:column;gap:2px}.ep-period-option{width:100%;text-align:left;padding:8px 12px;border-radius:7px;border:none;background:transparent;color:var(--muted);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s}.ep-period-option:hover{background:var(--accent-light);color:var(--accent)}.ep-period-option--active{background:var(--accent);color:#fff}.ep-period-option--active:hover{background:var(--accent-hover)}.ep-period-custom{padding:12px 14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}.ep-period-custom__row{display:flex;align-items:center;gap:8px}.ep-period-custom__row label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);width:20px;flex-shrink:0}.ep-period-custom__row input[type=date]{flex:1;height:34px;padding:0 10px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);outline:none;transition:border-color .15s}.ep-period-custom__row input[type=date]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.ep-period-custom__apply{margin-top:4px;width:100%;justify-content:center}.ep-error{padding:10px 14px;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:13px}.ep-loading{text-align:center;padding:72px;color:var(--muted);font-size:13px}.ep-warning{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;color:#92400e;font-size:13px}.ep-warning svg{color:#d97706;flex-shrink:0;margin-top:1px}.ep-empty{text-align:center;padding:72px var(--space-4);display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.ep-empty__icon{width:56px;height:56px;border-radius:14px;background:#dcfce7;display:flex;align-items:center;justify-content:center;color:#16a34a;margin-bottom:var(--space-2)}.ep-empty__title{font-size:15px;font-weight:600;color:var(--text)}.ep-empty__sub{font-size:13px;color:var(--muted);max-width:360px}.ep-kpis{display:flex;gap:var(--space-4)}.ep-kpi--main{flex:1.6}@media(max-width:900px){.ep-kpis{flex-wrap:wrap}.ep-kpi--main{flex:1 1 100%}.ep-kpi{flex:1 1 calc(50% - var(--space-4))}}.ep-kpi{flex:1;min-width:0;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:18px 22px;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;gap:5px}.ep-kpi--main{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#bbf7d0}.ep-kpi__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.ep-kpi__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;display:inline-block}.ep-kpi__value{font-size:1.4rem;font-weight:700;color:var(--text);letter-spacing:-.02em;font-variant-numeric:tabular-nums}.ep-kpi__value--big{font-size:2rem;color:#16a34a}.ep-kpi__sub{font-size:11px;color:var(--muted)}.ep-charts{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:800px){.ep-charts{grid-template-columns:1fr}}.ep-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 3px #0000000f,0 4px 16px #0000000a;overflow:hidden}.ep-card__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border)}.ep-card__title{font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.01em}.ep-card__count{font-size:12px;color:var(--muted)}.ep-card .recharts-wrapper{padding:12px 0 8px}.ep-tooltip{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:8px 12px;box-shadow:0 4px 16px #0000001a;font-size:12px}.ep-tooltip__label{font-weight:600;color:var(--text);margin-bottom:4px}.ep-tooltip__row{color:#16a34a;font-weight:700;font-variant-numeric:tabular-nums}.ep-table-card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;box-shadow:0 1px 3px #0000000f,0 4px 16px #0000000a;overflow:auto}.ep-table{width:100%;border-collapse:collapse;font-size:13px;white-space:nowrap}.ep-table th{padding:11px 16px;text-align:left;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--card-bg);position:sticky;top:0;z-index:1}.ep-table td{padding:11px 16px;color:var(--text);border-bottom:1px solid var(--border);vertical-align:middle}.ep-table tr:last-child td{border-bottom:none}.ep-table tbody tr:nth-child(2n) td{background:#00000003}.ep-table tbody tr:hover td{background:var(--accent-light)!important}.ep-table th.col-r,.ep-table td.col-r{text-align:right;font-variant-numeric:tabular-nums}.ep-row--missing td{opacity:.55}.ep-total-row{font-weight:700;color:var(--text)!important;background:#00000005!important;border-top:2px solid var(--border)!important}.ep-total-cell{color:#16a34a!important;font-weight:700}.ep-cat-cell{display:flex;align-items:center;gap:10px}.ep-cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.ep-progress-cell{display:flex;align-items:center;gap:10px;justify-content:flex-end}.ep-progress-cell span{font-size:12px;color:var(--muted);min-width:38px;text-align:right}.ep-progress{width:80px;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.ep-progress__bar{height:100%;border-radius:3px;transition:width .5s ease}.ep-produit-name{font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis;display:block}.ep-badge-cat{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:500;border:1px solid}.ep-filters{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ep-filters__select{height:36px;padding:0 10px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);outline:none;cursor:pointer;transition:border-color .15s}.ep-filters__select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.ep-filters__reset{display:inline-flex;align-items:center;gap:5px;padding:0 12px;height:36px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--muted);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.ep-filters__reset:hover{background:#fee2e2;color:#dc2626;border-color:#fecaca}.ep-kpi__footer{display:flex;align-items:center;justify-content:space-between;gap:8px}.ep-evo{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;padding:2px 7px;border-radius:6px}.ep-evo--up{background:#fee2e2;color:#dc2626}.ep-evo--down{background:#dcfce7;color:#16a34a}.ep-kpi--ratio{border-left:3px solid #6366f1}.ep-kpi--projection{border-left:3px solid #f59e0b;background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fde68a}.ep-kpi__value--warn{color:#dc2626}.ep-kpi__value--proj{color:#d97706}.ep-insights{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:16px 20px;box-shadow:0 1px 3px #0000000d}.ep-insights__title{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:12px}.ep-insights__title svg{color:var(--accent)}.ep-insights__list{display:flex;flex-direction:column;gap:8px}.ep-insight{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-radius:8px;font-size:13px;color:var(--text)}.ep-insight svg{flex-shrink:0;margin-top:1px}.ep-insight__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:3px}.ep-insight--cat{background:#6366f10d;border:1px solid rgba(99,102,241,.12)}.ep-insight--prod{background:#6366f10a;border:1px solid var(--border)}.ep-insight--warn{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.ep-insight--warn svg{color:#d97706}.ep-insight--good{background:#f0fdf4;border:1px solid #bbf7d0;color:#14532d}.ep-insight--good svg{color:#16a34a}.ep-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}@media(max-width:900px){.ep-bottom-grid{grid-template-columns:1fr}}.ep-top-list{display:flex;flex-direction:column}.ep-top-empty{padding:24px;text-align:center;color:var(--muted);font-size:13px}.ep-top-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);transition:background .12s}.ep-top-item:last-child{border-bottom:none}.ep-top-item:hover{background:var(--accent-light)}.ep-top-rank{font-size:13px;font-weight:700;color:var(--muted);width:18px;flex-shrink:0;text-align:center}.ep-top-info{flex:1;min-width:0}.ep-top-name{font-size:13px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ep-top-meta{display:flex;align-items:center;gap:8px;margin-top:3px;font-size:11px;color:var(--muted)}.ep-top-value{font-size:13px;font-weight:700;color:#16a34a;white-space:nowrap;font-variant-numeric:tabular-nums;flex-shrink:0}.ep-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.02em}.ep-badge--warn{background:#fee2e2;color:#dc2626;border:1px solid #fecaca}.ep-table-toolbar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}.ep-table-search{position:relative;display:flex;align-items:center;flex:1;min-width:180px;max-width:280px}.ep-table-search__icon{position:absolute;left:10px;color:var(--muted);pointer-events:none}.ep-table-search__input{width:100%;height:34px;padding:0 32px 0 30px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);color:var(--text);font-size:13px;font-family:var(--font);outline:none;transition:border-color .15s}.ep-table-search__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.ep-table-search__input::placeholder{color:var(--muted);opacity:.7}.ep-table-search__clear{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:var(--muted);padding:2px;display:flex;align-items:center}.ep-table-search__clear:hover{color:var(--text)}.ep-sort-btns{display:flex;gap:4px;flex-wrap:wrap}.ep-sort-btn{display:inline-flex;align-items:center;gap:3px;padding:4px 10px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.ep-sort-btn:hover{background:var(--accent-light);color:var(--accent)}.ep-sort-btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}.ep-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border);gap:var(--space-3);flex-wrap:wrap}.ep-pagination__info{font-size:12px;color:var(--muted)}.ep-pagination__controls{display:flex;align-items:center;gap:4px}.ep-pagination__page{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--muted);font-size:13px;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s}.ep-pagination__page:hover{background:var(--accent-light);color:var(--accent)}.ep-pagination__page--active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.ep-pagination__size{display:flex;align-items:center;gap:4px;background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:3px}.ep-pagination__size-btn{padding:3px 10px;border-radius:5px;border:none;background:transparent;color:var(--muted);font-size:12px;font-weight:500;font-family:var(--font);cursor:pointer;transition:background .12s,color .12s}.ep-pagination__size-btn:hover{color:var(--text)}.ep-pagination__size-btn--active{background:var(--accent);color:#fff;font-weight:600}.badge-channel{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:500;background:#6366f114;color:#6366f1;border:1px solid rgba(99,102,241,.15)}.ep-progress-cell{display:flex;align-items:center;gap:8px;justify-content:flex-end}.ep-progress-cell span{font-size:12px;color:var(--muted);min-width:36px;text-align:right}.btn-primary{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .15s ease}.btn-primary:hover{background:var(--accent-hover)}.support-page{width:100%;display:flex;flex-direction:column;height:100%}.support-layout{display:grid;grid-template-columns:260px 1fr;gap:var(--space-4);flex:1;min-height:0;height:calc(100vh - 120px)}.support-sidebar{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden}.support-sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-4) var(--space-3);border-bottom:1px solid var(--border);flex-shrink:0}.support-sidebar__title{font-size:var(--text-sm);font-weight:600;color:var(--text)}.support-sidebar__new{width:26px;height:26px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition);line-height:1}.support-sidebar__new:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.support-sidebar__search{display:flex;align-items:center;gap:var(--space-2);margin:var(--space-3) var(--space-3) var(--space-2);padding:5px 8px;background:var(--card-bg-alt);border:1px solid var(--border);border-radius:var(--radius-sm)}.support-sidebar__search-icon{font-size:.7rem;flex-shrink:0;opacity:.5}.support-sidebar__search-input{flex:1;border:none;background:transparent;font-size:var(--text-xs);font-family:var(--font);color:var(--text);outline:none;min-width:0}.support-sidebar__search-input::placeholder{color:var(--muted-light)}.support-sidebar__search-clear{border:none;background:transparent;color:var(--muted-light);font-size:.65rem;cursor:pointer;padding:0;display:flex;align-items:center;flex-shrink:0}.support-sidebar__search-clear:hover{color:var(--text)}.support-sidebar__loading{display:flex;justify-content:center;padding:var(--space-6)}.support-sidebar__empty{padding:var(--space-5) var(--space-4);font-size:var(--text-xs);color:var(--muted-light);font-style:italic;text-align:center}.support-conv-list{list-style:none;margin:0;padding:var(--space-2) 0;overflow-y:auto;flex:1}.support-conv-item{position:relative;padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--border-light)}.support-conv-item:hover{background:var(--card-bg-alt)}.support-conv-item.active{background:var(--accent-light);border-left:3px solid var(--accent)}.support-conv-item__title{font-size:var(--text-xs);font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:20px}.support-conv-item__meta{display:flex;gap:var(--space-2);margin-top:3px;align-items:center}.support-conv-item__lang{font-size:.65rem;color:var(--muted-light);background:var(--border-light);border-radius:var(--radius-sm);padding:1px 5px}.support-conv-item__date{font-size:.65rem;color:var(--muted-light)}.support-conv-item__delete{position:absolute;top:8px;right:8px;width:18px;height:18px;border:none;background:transparent;color:var(--muted-light);font-size:var(--text-xs);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);opacity:0;transition:opacity var(--transition),background var(--transition),color var(--transition)}.support-conv-item:hover .support-conv-item__delete{opacity:1}.support-conv-item__delete:hover{background:var(--danger-bg);color:var(--danger)}.support-conv-item__top{display:flex;align-items:center;gap:4px;padding-right:22px}.support-conv-item__top .support-conv-item__title{padding-right:0;flex:1;min-width:0}.support-conv-item__edit-name{border:none;background:transparent;cursor:pointer;font-size:.7rem;padding:0;flex-shrink:0;opacity:0;transition:opacity var(--transition);line-height:1}.support-conv-item:hover .support-conv-item__edit-name{opacity:1}.support-conv-item__name-edit{display:flex;flex-direction:column;gap:var(--space-2);padding:2px 0}.support-name-input{width:100%;padding:4px 8px;font-size:var(--text-xs);font-family:var(--font);border:1px solid var(--accent);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text);outline:none;box-shadow:0 0 0 2px var(--accent-ring);box-sizing:border-box}.support-name-edit__actions{display:flex;gap:var(--space-2)}.support-name-edit__ok,.support-name-edit__cancel{flex:1;padding:4px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);font-family:var(--font);transition:background var(--transition)}.support-name-edit__ok{background:var(--success-bg);color:var(--success)}.support-name-edit__ok:hover:not(:disabled){background:var(--success);color:#fff}.support-name-edit__cancel{background:var(--border-light);color:var(--muted)}.support-name-edit__cancel:hover{background:var(--danger-bg);color:var(--danger)}.support-main{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden}.support-thread{flex:1;overflow-y:auto;padding:var(--space-5) var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);min-height:0}.support-thread__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--muted);font-size:var(--text-sm);gap:var(--space-2);padding:var(--space-8)}.support-thread__empty-icon{font-size:2.5rem;margin-bottom:var(--space-2)}.support-thread__empty-sub{font-size:var(--text-xs);color:var(--muted-light)}.support-exchange{display:flex;flex-direction:column;gap:var(--space-3)}.support-exchange--bordered{padding-top:var(--space-4);border-top:1px solid var(--border-light)}.support-bubble{border-radius:var(--radius-md);padding:var(--space-4);border:1px solid var(--border)}.support-bubble--client{background:var(--card-bg-alt);border-color:var(--border)}.support-bubble--response{background:var(--accent-light);border-color:var(--accent-ring)}.support-bubble__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.support-bubble__label{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.support-bubble__text{font-size:var(--text-sm);color:var(--text);white-space:pre-wrap;line-height:1.6}.support-bubble__text--response{color:var(--text)}.support-bubble--client .support-bubble__label{margin-bottom:var(--space-2)}.support-bubble__date{margin-top:var(--space-2);font-size:.65rem;color:var(--muted-light);text-align:right}.support-copy-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--card-bg);color:var(--muted);font-size:var(--text-xs);font-family:var(--font);font-weight:500;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition);white-space:nowrap}.support-copy-btn:hover{background:var(--border-light);color:var(--text-secondary)}.support-copy-btn.copied{background:var(--success-bg);border-color:var(--success-border);color:var(--success)}.support-reprompt{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--card-bg-alt);border:1px solid var(--border);border-radius:var(--radius);margin-top:var(--space-1)}.support-textarea--reprompt{font-size:var(--text-xs);resize:none}.support-reprompt__actions{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.support-reprompt__count{font-size:var(--text-xs);color:var(--muted-light)}.support-btn--secondary{display:inline-flex;align-items:center;gap:var(--space-2);padding:7px var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;font-family:var(--font);border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary);cursor:pointer;transition:background .15s cubic-bezier(.4,0,.2,1),border-color .15s cubic-bezier(.4,0,.2,1);white-space:nowrap;outline:none}.support-btn--secondary:hover:not(:disabled){background:var(--border-light);color:var(--text)}.support-btn--secondary:disabled{opacity:.5;cursor:not-allowed}.support-input-zone{border-top:1px solid var(--border);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-3);flex-shrink:0;background:var(--card-bg)}.support-new-client{display:flex;gap:var(--space-3)}.support-new-client__input{flex:1;padding:7px 12px;font-size:var(--text-sm);font-family:var(--font);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg-alt);color:var(--text);outline:none;transition:border-color var(--transition),box-shadow var(--transition);min-width:0}.support-new-client__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.support-new-client__input::placeholder{color:var(--muted-light)}.support-new-client__input:disabled{opacity:.5}.support-lang-selector{display:flex;gap:var(--space-2)}.support-chip{padding:5px 12px;border-radius:var(--radius-full);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:var(--text-xs);font-family:var(--font);font-weight:500;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition)}.support-chip:hover:not(:disabled){background:var(--border-light);color:var(--text)}.support-chip--active{background:var(--accent);border-color:var(--accent);color:#fff}.support-chip--active:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);color:#fff}.support-chip:disabled{opacity:.5;cursor:not-allowed}.support-form{display:flex;flex-direction:column;gap:var(--space-3)}.support-textarea{width:100%;resize:vertical;padding:var(--space-3) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card-bg-alt);color:var(--text);font-size:var(--text-sm);font-family:var(--font);line-height:1.6;transition:border-color var(--transition),box-shadow var(--transition);outline:none;box-sizing:border-box}.support-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.support-textarea:disabled{opacity:.6;cursor:not-allowed}.support-textarea::placeholder{color:var(--muted-light)}.support-textarea--context{min-height:unset;font-size:12px;opacity:.85;border-style:dashed}.support-textarea--listening{border-color:#ef4444;border-style:solid;opacity:1;box-shadow:0 0 0 3px #ef444426}.support-context-wrap{position:relative}.support-context-wrap .support-textarea--context{padding-right:40px}.support-mic-btn{position:absolute;top:7px;right:7px;width:26px;height:26px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition),border-color var(--transition),color var(--transition)}.support-mic-btn:hover:not(:disabled){background:var(--border-light);border-color:var(--accent);color:var(--accent)}.support-mic-btn--active{background:#fee2e2;border-color:#ef4444;color:#ef4444;animation:mic-pulse 1.4s ease-in-out infinite}.support-mic-btn--active:hover:not(:disabled){background:#fecaca}@keyframes mic-pulse{0%,to{box-shadow:0 0 #ef44444d}50%{box-shadow:0 0 0 4px #ef444400}}.support-mic-btn:disabled{opacity:.35;cursor:not-allowed}.support-form__actions{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.support-form__hint{font-size:var(--text-xs);color:var(--muted-light);display:flex;flex-direction:column;gap:2px}.support-form__shortcut{font-size:.65rem;color:var(--muted-light);opacity:.7}.support-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:9px var(--space-5);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;font-family:var(--font);border:1px solid transparent;cursor:pointer;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition);white-space:nowrap;outline:none}.support-btn:disabled{opacity:.5;cursor:not-allowed}.support-btn:focus-visible{box-shadow:0 0 0 3px var(--accent-ring)}.support-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.support-btn--primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.support-loading{display:flex;align-items:center;gap:var(--space-3);color:var(--muted-light);font-size:var(--text-sm)}.support-spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:support-spin .7s linear infinite;flex-shrink:0;display:inline-block}.support-spinner--sm{width:14px;height:14px}@keyframes support-spin{to{transform:rotate(360deg)}}.support-error{padding:var(--space-3) var(--space-4);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius);color:var(--danger);font-size:var(--text-sm)}@media(max-width:768px){.support-layout{grid-template-columns:1fr;height:auto}.support-sidebar{max-height:200px}.support-main{min-height:500px}}.gen-page{display:flex;gap:var(--space-6);height:calc(100vh - 64px);overflow:hidden}.gen-sidebar{width:340px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-3);overflow-y:auto;padding:var(--space-1) var(--space-2) var(--space-6) 0}.gen-main{flex:1;display:flex;flex-direction:column;gap:var(--space-4);overflow-y:auto;min-width:0}.gen-step{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.gen-step__header{display:flex;align-items:center;gap:var(--space-3)}.gen-step__num{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-size:var(--text-xs);font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.gen-step__num--2{background:#7c3aed}.gen-step__num--3{background:#0ea5e9}.gen-step__title{font-size:var(--text-sm);font-weight:700;color:var(--text);margin:0}.gen-step__sub{font-size:var(--text-xs);color:var(--muted);margin:2px 0 0}.gen-step-arrow{display:flex;justify-content:center;color:var(--muted-light)}.gen-textarea-wrap{display:flex;flex-direction:column;gap:var(--space-2)}.gen-textarea{resize:vertical;min-height:90px;padding:var(--space-3);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--text-sm);font-family:var(--font);color:var(--text);background:var(--card-bg);outline:none;line-height:1.6;transition:border-color var(--transition),box-shadow var(--transition);width:100%;box-sizing:border-box}.gen-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.gen-textarea::placeholder{color:var(--muted-light)}.gen-textarea:disabled{opacity:.6;cursor:not-allowed}.gen-textarea-actions{display:flex;align-items:center;gap:var(--space-2)}.gen-upload{display:flex;align-items:center;gap:var(--space-2);flex:1;flex-wrap:wrap}.gen-upload__thumb{position:relative;width:36px;height:36px;border-radius:var(--radius);overflow:hidden;flex-shrink:0}.gen-upload__thumb img{width:100%;height:100%;object-fit:cover}.gen-upload__remove{position:absolute;top:1px;right:1px;width:14px;height:14px;border-radius:50%;background:#000000a6;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.gen-upload__add{width:36px;height:36px;border-radius:var(--radius);border:1px dashed var(--border);background:var(--border-light);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color var(--transition),color var(--transition),background var(--transition);flex-shrink:0}.gen-upload__add:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.gen-upload__add:disabled{opacity:.5;cursor:not-allowed}.gen-mic{width:36px;height:36px;border-radius:var(--radius);border:1px solid var(--border);background:var(--card-bg);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color var(--transition),color var(--transition),background var(--transition)}.gen-mic:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.gen-mic--active{background:#fee2e2;border-color:#ef4444;color:#ef4444;animation:gen-mic-pulse 1.2s ease-in-out infinite}@keyframes gen-mic-pulse{0%,to{box-shadow:0 0 #ef44444d}50%{box-shadow:0 0 0 5px #ef444400}}.gen-mic:disabled{opacity:.4;cursor:not-allowed}.gen-ratio-row{display:flex;gap:var(--space-1);flex-wrap:wrap}.gen-chip{padding:4px 10px;border-radius:var(--radius-full);border:1px solid var(--border);background:transparent;font-size:11px;font-weight:600;color:var(--muted);cursor:pointer;font-family:var(--font);transition:border-color var(--transition),background var(--transition),color var(--transition)}.gen-chip:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.gen-chip--active{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.gen-chip:disabled{opacity:.5;cursor:not-allowed}.gen-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:9px var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);font-weight:600;font-family:var(--font);border:1px solid transparent;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition);white-space:nowrap;width:100%}.gen-btn:disabled{opacity:.5;cursor:not-allowed}.gen-btn--primary{background:#7c3aed;color:#fff;border-color:#7c3aed}.gen-btn--primary:hover:not(:disabled){background:#6d28d9;border-color:#6d28d9}.gen-btn--secondary{background:var(--accent);color:#fff;border-color:var(--accent)}.gen-btn--secondary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.gen-btn--refine{background:#0ea5e9;color:#fff;border-color:#0ea5e9}.gen-btn--refine:hover:not(:disabled){background:#0284c7;border-color:#0284c7}.gen-btn--outline{background:transparent;color:var(--text-secondary);border-color:var(--border);width:auto;padding:7px var(--space-3);font-size:var(--text-xs)}.gen-btn--outline:hover:not(:disabled){background:var(--border-light);color:var(--text)}.gen-btn--danger{background:transparent;color:#e05252;border-color:#e05252;width:auto;padding:7px var(--space-3);font-size:var(--text-xs)}.gen-btn--danger:hover:not(:disabled){background:#fef2f2}.gen-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:gen-spin .7s linear infinite;flex-shrink:0}.gen-spinner--dark{border-color:#00000026;border-top-color:var(--muted)}@keyframes gen-spin{to{transform:rotate(360deg)}}.gen-error{padding:var(--space-2) var(--space-3);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius);color:var(--danger);font-size:var(--text-xs)}.gen-viewer{display:flex;align-items:center;justify-content:center;min-height:300px;max-height:65vh;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:relative}.gen-result__img{max-width:100%;max-height:65vh;object-fit:contain;border-radius:var(--radius)}.gen-result__meta{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.gen-result__model{font-size:var(--text-xs);color:var(--muted);background:var(--surface-2, #f4f4f5);border-radius:999px;padding:2px 10px;white-space:nowrap;flex-shrink:0}.gen-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-5);text-align:center;padding:var(--space-6)}.gen-loading__spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:#7c3aed;border-radius:50%;animation:gen-spin .9s linear infinite}.gen-loading__title{font-size:var(--text-base);font-weight:600;color:var(--text);margin:0}.gen-loading__sub{font-size:var(--text-sm);color:var(--muted-light);margin:var(--space-1) 0 0}.gen-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);color:var(--muted-light);text-align:center;padding:var(--space-6)}.gen-empty p{font-size:var(--text-sm);max-width:240px;line-height:1.6;margin:0}.gen-gallery{display:flex;flex-direction:column;gap:var(--space-2);flex-shrink:0}.gen-gallery__title{font-size:var(--text-xs);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0}.gen-gallery__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-2)}.gen-gallery__wrap{position:relative}.gen-gallery__wrap:hover .gen-gallery__delete{opacity:1}.gen-gallery__delete{position:absolute;top:3px;right:3px;width:20px;height:20px;border-radius:4px;background:#0000008c;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;opacity:0;transition:opacity var(--transition);z-index:2}.gen-gallery__delete:hover{background:#e05252}.gen-gallery__item{aspect-ratio:1;border-radius:var(--radius);overflow:hidden;border:2px solid transparent;cursor:pointer;padding:0;background:var(--border-light);transition:border-color var(--transition),transform var(--transition)}.gen-gallery__item:hover{transform:scale(1.04);border-color:var(--border)}.gen-gallery__item--active{border-color:var(--accent)}.gen-gallery__item--failed{opacity:.5}.gen-gallery__item img{width:100%;height:100%;object-fit:cover;display:block}.gen-gallery__status{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:16px}.gen-gallery__status--failed{color:var(--danger)}.gen-gallery__status--pending{color:var(--muted)}.gen-tooltip-wrap{position:relative;cursor:not-allowed}.gen-tooltip-wrap button{pointer-events:none}.gen-tooltip-wrap:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#1e1e2e;color:#fff;font-size:12px;font-weight:500;white-space:nowrap;padding:6px 10px;border-radius:6px;pointer-events:none;opacity:0;transition:opacity .15s;z-index:100}.gen-tooltip-wrap:before{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1e1e2e;pointer-events:none;opacity:0;transition:opacity .15s;z-index:100}.gen-tooltip-wrap:hover:after,.gen-tooltip-wrap:hover:before{opacity:1}.gen-gate{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);height:calc(100vh - 200px);text-align:center;color:var(--muted)}.gen-gate__title{font-size:var(--text-xl);font-weight:700;color:var(--text);margin:0}.gen-gate__text{font-size:var(--text-sm);color:var(--muted);max-width:300px;line-height:1.6;margin:0}@media(max-width:768px){.gen-page{flex-direction:column;height:auto;overflow:visible}.gen-sidebar{width:100%}.gen-main{min-height:300px}.gen-viewer{min-height:280px}}.abo-page{max-width:860px;margin:0 auto;padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;gap:var(--space-6)}.abo-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4)}.abo-title{font-size:var(--text-2xl);font-weight:700;color:var(--text);margin:0}.abo-sub{font-size:var(--text-sm);color:var(--muted);margin:0}.abo-plan-badge{display:inline-block;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.abo-plan-badge--free{background:var(--border-light);color:var(--muted)}.abo-plan-badge--basic{background:#dbeafe;color:#1d4ed8}.abo-plan-badge--premium{background:#f3e8ff;color:#7c3aed}.abo-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5);align-items:start}.abo-card{position:relative;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5);transition:box-shadow var(--transition),border-color var(--transition)}.abo-card--highlight{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow-md)}.abo-card--active{border-color:var(--success, #16a34a)}.abo-card__badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--accent);color:#fff;font-size:var(--text-xs);font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:3px 14px;border-radius:var(--radius-full);white-space:nowrap}.abo-card__header{display:flex;flex-direction:column;gap:var(--space-2)}.abo-card__name{font-size:var(--text-lg);font-weight:700;color:var(--text);margin:0}.abo-card__price{display:flex;align-items:baseline;gap:4px}.abo-card__amount{font-size:2rem;font-weight:800;color:var(--text);line-height:1}.abo-card__period{font-size:var(--text-sm);color:var(--muted)}.abo-card__features{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.abo-card__feature{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text)}.abo-card__feature--excluded{color:var(--muted-light);text-decoration:line-through}.abo-card__check{color:var(--accent);flex-shrink:0}.abo-card__feature--excluded .abo-card__check{color:var(--muted-light)}.abo-card__footer{margin-top:auto}.abo-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:10px var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);font-weight:600;font-family:var(--font);border:1px solid transparent;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition)}.abo-btn:disabled{opacity:.5;cursor:not-allowed}.abo-btn--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.abo-btn--primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.abo-btn--outline{background:transparent;color:var(--text);border-color:var(--border)}.abo-btn--outline:hover:not(:disabled){background:var(--border-light)}.abo-btn--manage{background:#ff8344;color:#fff;border-color:#ff8344;width:auto;padding:9px 18px}.abo-btn--manage:hover:not(:disabled){background:#e8702e;border-color:#e8702e}.abo-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:abo-spin .7s linear infinite;flex-shrink:0}@keyframes abo-spin{to{transform:rotate(360deg)}}.abo-error{padding:var(--space-3) var(--space-4);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius);color:var(--danger);font-size:var(--text-sm)}.abo-details{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-5)}.abo-details__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.abo-details__title{font-size:var(--text-base);font-weight:700;color:var(--text);margin:0}.abo-details__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4)}.abo-details__group{display:flex;flex-direction:column;gap:4px}.abo-details__label{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.abo-details__value{font-size:var(--text-sm);color:var(--text);font-weight:500}.abo-details__value--mono{font-family:monospace;font-size:var(--text-xs);color:var(--muted)}.abo-details__value--warning{color:#b45309}.abo-status{display:inline-block;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.abo-status--active{background:#dcfce7;color:#16a34a}.abo-status--trialing{background:#dbeafe;color:#1d4ed8}.abo-status--canceled{background:#f3f4f6;color:#6b7280}.abo-status--danger{background:#fee2e2;color:#dc2626}.abo-invoice{background:var(--border-light);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.abo-invoice__header{display:flex;align-items:center;gap:var(--space-2)}.abo-invoice__title{font-size:var(--text-sm);font-weight:700;color:var(--text);flex:1}.abo-invoice__actions{display:flex;gap:var(--space-2);flex-wrap:wrap}.abo-btn--sm{padding:6px var(--space-3);font-size:var(--text-xs)}.abo-details-loading{font-size:var(--text-sm);color:var(--muted);text-align:center;padding:var(--space-4)}.abo-footer-note{text-align:center;font-size:var(--text-xs);color:var(--muted-light);margin:0}@media(max-width:640px){.abo-cards{grid-template-columns:1fr}}.accueil-page{width:100%;display:flex;flex-direction:column;gap:var(--space-5)}.accueil-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:12px var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);font-weight:500;animation:banner-in .35s cubic-bezier(.16,1,.3,1)}@keyframes banner-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.accueil-banner--orange{background:#fff7ed;border:1px solid #fed7aa;color:#92400e}.accueil-banner--blue{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.accueil-banner--green{background:#f0fdf4;border:1px solid #bbf7d0;color:#14532d}.accueil-banner--red{background:#fef2f2;border:1px solid #fecaca;color:#7f1d1d}.accueil-banner__text{flex:1;line-height:1.5}.accueil-banner__close{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;opacity:.6;padding:2px;border-radius:4px;transition:opacity var(--transition);flex-shrink:0}.accueil-banner__close:hover{opacity:1}.accueil-hero{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.accueil-hero__title{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;color:var(--text);margin:0 0 4px;line-height:1.2}.accueil-hero__name{background:linear-gradient(135deg,#ff8344,#f43f5e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.accueil-hero__sub{font-size:var(--text-sm);color:var(--muted);margin:0}.accueil-hero__right{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.accueil-plan-chip{display:inline-flex;align-items:center;padding:5px 14px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:800;text-transform:uppercase;letter-spacing:.06em}.accueil-plan-chip--free{background:#f3f4f6;color:#6b7280}.accueil-plan-chip--basic{background:#dbeafe;color:#1d4ed8}.accueil-plan-chip--premium{background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;box-shadow:0 2px 8px #7c3aed59}.accueil-trial-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}.accueil-upgrade-btn{padding:7px 16px;border-radius:var(--radius-full);background:linear-gradient(135deg,#ff8344,#f43f5e);color:#fff;font-size:var(--text-xs);font-weight:700;border:none;cursor:pointer;box-shadow:0 2px 10px #ff834466;transition:box-shadow var(--transition),transform var(--transition)}.accueil-upgrade-btn:hover{box-shadow:0 4px 16px #ff834480;transform:translateY(-1px)}.accueil-section__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);color:var(--muted)}.accueil-section__title{font-size:var(--text-sm);font-weight:700;color:var(--text);margin:0;flex:1;text-transform:uppercase;letter-spacing:.05em}.accueil-section__link{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-xs);font-weight:600;color:#ff8344;background:none;border:none;cursor:pointer;padding:0;transition:gap var(--transition)}.accueil-section__link:hover{gap:6px}.accueil-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.accueil-kpi{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-1);transition:box-shadow var(--transition),transform var(--transition);position:relative;overflow:hidden}.accueil-kpi:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#ff8344,#f43f5e);opacity:0;transition:opacity var(--transition)}.accueil-kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.accueil-kpi:hover:before{opacity:1}.accueil-kpi__label{font-size:var(--text-xs);font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.accueil-kpi__value{font-size:1.5rem;font-weight:800;color:var(--text);line-height:1.2;min-height:1.8rem}.accueil-kpi__value--channel{font-size:1.1rem}.accueil-kpi__trend{display:inline-flex;align-items:center;gap:3px;font-size:var(--text-xs);font-weight:600;margin-top:2px}.accueil-kpi__trend--up{color:#16a34a}.accueil-kpi__trend--down{color:#dc2626}.accueil-row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);align-items:start}.accueil-row-2>*{min-width:0}.accueil-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column}.accueil-card--spark{gap:var(--space-3)}.accueil-sparkline{width:100%;height:64px;display:block}.accueil-spark-placeholder{height:64px;background:var(--border-light);border-radius:var(--radius);animation:shimmer 1.5s ease-in-out infinite}.accueil-card--quotas{gap:var(--space-4)}.accueil-quotas{display:flex;flex-direction:column;gap:var(--space-3);flex:1}.accueil-quota__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.accueil-quota__label{font-size:var(--text-xs);font-weight:600;color:var(--muted)}.accueil-quota__count{font-size:var(--text-xs);font-weight:700;color:var(--text)}.accueil-quota__count--full{color:#dc2626}.accueil-quota__track{height:6px;background:var(--border-light);border-radius:99px;overflow:hidden}.accueil-quota__fill{height:100%;background:linear-gradient(90deg,#ff8344,#f43f5e);border-radius:99px;transition:width .6s cubic-bezier(.34,1.56,.64,1)}.accueil-quota__fill--full{background:linear-gradient(90deg,#ef4444,#dc2626)}.accueil-quota-stat{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--muted);padding-top:var(--space-1)}.accueil-upgrade-link{display:inline-flex;align-items:center;gap:5px;font-size:var(--text-xs);font-weight:700;color:#ff8344;background:none;border:none;cursor:pointer;padding:0;margin-top:var(--space-2);transition:gap var(--transition)}.accueil-upgrade-link:hover{gap:8px}.accueil-feed{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0}.accueil-feed__item{display:flex;align-items:center;gap:var(--space-3);padding:10px 0;border-bottom:1px solid var(--border-light)}.accueil-feed__item:last-child{border-bottom:none}.accueil-feed__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.accueil-feed__dot--orange{background:#ff8344}.accueil-feed__dot--purple{background:#7c3aed}.accueil-feed__body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.accueil-feed__main{font-size:var(--text-sm);font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.accueil-feed__meta{font-size:var(--text-xs);color:var(--muted)}.accueil-feed__amount{font-size:var(--text-sm);font-weight:700;color:var(--text);white-space:nowrap}.accueil-shortcuts{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.accueil-shortcut{display:flex;align-items:center;gap:var(--space-3);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);cursor:pointer;text-align:left;transition:box-shadow var(--transition),transform var(--transition),border-color var(--transition)}.accueil-shortcut:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--shortcut-color, #ff8344)}.accueil-shortcut__icon{width:40px;height:40px;border-radius:var(--radius);background:color-mix(in srgb,var(--shortcut-color, #ff8344) 12%,transparent);color:var(--shortcut-color, #ff8344);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--transition)}.accueil-shortcut:hover .accueil-shortcut__icon{background:color-mix(in srgb,var(--shortcut-color, #ff8344) 20%,transparent)}.accueil-shortcut__text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.accueil-shortcut__label{font-size:var(--text-sm);font-weight:700;color:var(--text)}.accueil-shortcut__desc{font-size:var(--text-xs);color:var(--muted)}.accueil-shortcut__arrow{color:var(--muted);flex-shrink:0;opacity:0;transform:translate(-4px);transition:opacity var(--transition),transform var(--transition)}.accueil-shortcut:hover .accueil-shortcut__arrow{opacity:1;transform:translate(0)}.accueil-skeleton{display:inline-block;width:80px;height:1.5rem;background:var(--border-light);border-radius:var(--radius);animation:shimmer 1.5s ease-in-out infinite}.accueil-skeleton--row{display:block;width:100%;height:44px;border-radius:var(--radius);margin-bottom:var(--space-2);background:var(--border-light);animation:shimmer 1.5s ease-in-out infinite}@keyframes shimmer{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.accueil-empty{font-size:var(--text-sm);color:var(--muted);margin:0;padding:var(--space-4) 0}@media(max-width:768px){.accueil-kpis{grid-template-columns:repeat(2,1fr)}.accueil-row-2{grid-template-columns:1fr}.accueil-shortcuts{grid-template-columns:1fr 1fr}}@media(max-width:480px){.accueil-kpis,.accueil-shortcuts{grid-template-columns:1fr}}
