*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.fixed{position:fixed}.block{display:block}.table{display:table}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.border{border-width:1px}.blur{--tw-blur:blur(8px)}.blur,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);color:#2d3748;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6}.App{display:flex;flex-direction:column;min-height:100vh}:root{--primary-color:#000;--primary-dark:#333;--primary-light:#666;--secondary-color:#6c757d;--danger-color:#dc3545;--success-color:#28a745;--warning-color:#ffc107;--info-color:#17a2b8;--light-color:#f8f9fa;--dark-color:#343a40;--border-color:#e9ecef;--shadow:0 4px 20px #0000001a;--shadow-hover:0 8px 30px #00000026;--border-radius:0px;--transition:all 0.3s cubic-bezier(0.4,0,0.2,1)}.login-container{align-items:center;background:linear-gradient(135deg,#000,#333);background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:2rem;position:relative}.login-container:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='25' cy='25' r='1' fill='rgba(255,255,255,0.05)'/%3E%3Ccircle cx='75' cy='75' r='1' fill='rgba(255,255,255,0.05)'/%3E%3Ccircle cx='50' cy='10' r='.5' fill='rgba(255,255,255,0.03)'/%3E%3Ccircle cx='10' cy='60' r='.5' fill='rgba(255,255,255,0.03)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E") repeat;bottom:0;content:"";left:0;opacity:.5;position:absolute;right:0;top:0}.login-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #fff3;border-radius:0;box-shadow:0 20px 40px #00000026;max-width:420px;padding:2.5rem;position:relative;text-align:center;width:100%;z-index:1}.login-header{margin-bottom:2rem}.login-header .login-logo{display:block;height:auto;margin:0 auto .8rem;max-width:240px}.login-header h1{color:#000;color:var(--primary-color);font-size:2.2rem;font-weight:700;margin-bottom:.5rem;text-shadow:0 2px 4px #0000001a}.login-header .subtitle{color:#6c757d;color:var(--secondary-color);font-size:1rem;font-weight:400;margin:0;opacity:.8}.login-form{text-align:left}.login-form .form-group{margin-bottom:1.8rem}.login-form .form-group label{color:#343a40;color:var(--dark-color);display:block;font-size:.95rem;font-weight:600;margin-bottom:.6rem}.login-form .form-group input{background:#f8f9fa;border:2px solid #e9ecef;border-radius:0;font-size:1rem;padding:1rem;transition:all .3s ease;width:100%}.login-form .form-group input:focus{background:#fff;border-color:#000;border-color:var(--primary-color);box-shadow:0 0 0 3px #8cc63f1a;outline:none}.btn-login{border-radius:0;font-size:1.1rem;font-weight:600;letter-spacing:.5px;margin-bottom:1.5rem;padding:1rem;text-transform:uppercase;transition:all .3s ease;width:100%}.btn-login:hover{box-shadow:0 8px 20px #8cc63f4d;transform:translateY(-2px)}.login-links{margin-top:1rem;text-align:center}.forgot-password-link{background:none;border:none;color:#000;color:var(--primary-color);cursor:pointer;font-size:.9rem;text-decoration:underline;transition:color .3s ease}.forgot-password-link:hover{color:#333;color:var(--primary-dark)}.link-separator{color:#6c757d;color:var(--secondary-color);font-size:.9rem;margin:0 .5rem}.forgot-password-header{margin-bottom:1.5rem;text-align:center}.forgot-password-header h3{color:#343a40;color:var(--dark-color);font-size:1.4rem;margin-bottom:.5rem}.forgot-password-header p{color:#6c757d;color:var(--secondary-color);font-size:.9rem;line-height:1.4}.form-actions-row{display:flex;gap:1rem;margin-top:1.5rem}.form-actions-row .btn{border-radius:0;flex:1 1;font-weight:600;padding:.8rem}.login-footer{border-top:1px solid #e9ecef;margin-top:2rem;padding-top:1.5rem}.login-footer .branding{text-align:center}.toggle-group{margin:2rem 0}.toggle-container{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #dee2e6;border-radius:0;box-shadow:0 4px 12px #0000001a;padding:1.5rem}.toggle-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.toggle-title{color:#343a40;flex:1 1;font-size:1.1rem;font-weight:700;margin:0}.toggle-switch{display:inline-block;height:34px;position:relative;width:60px}.toggle-checkbox{height:0;opacity:0;width:0}.toggle-label{background-color:#ccc;border-radius:34px;bottom:0;cursor:pointer;left:0;right:0;top:0}.toggle-label,.toggle-slider{position:absolute;transition:all .4s ease}.toggle-slider{background-color:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;content:"";height:26px;left:4px;top:50%;transform:translateY(-50%);width:26px}.toggle-checkbox:checked+.toggle-label{background-color:#000;background-color:var(--primary-color)}.toggle-checkbox:checked+.toggle-label .toggle-slider{transform:translateX(26px) translateY(-50%)}.toggle-label:hover{box-shadow:0 0 1px #000;box-shadow:0 0 1px var(--primary-color)}.toggle-description{margin-top:1rem}.toggle-text-active,.toggle-text-inactive{border-radius:0;font-size:.9rem;line-height:1.4;margin:.5rem 0;padding:.75rem}.toggle-text-active{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.toggle-text-inactive{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.user-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.btn-action{background:#0000!important;border:none;border-radius:8px;color:#6b7280;display:inline-flex;font-size:.85rem;padding:0;position:relative;transition:all .2s ease;width:32px}.portal-tooltip{animation:tooltipFadeIn .12s ease-out;background:#111827;border-radius:6px;box-shadow:0 6px 16px -4px #00000040;color:#fff;font-size:.75rem;font-weight:500;padding:.35rem .6rem;pointer-events:none;position:fixed;white-space:nowrap;z-index:10000}.portal-tooltip.tip-multi{font-weight:400;line-height:1.45;padding:.5rem .7rem;text-align:left;white-space:normal;width:280px}.portal-tooltip:after{border:5px solid #0000;content:"";left:50%;position:absolute}.portal-tooltip.tip-above:after{border-top-color:#111827;bottom:-10px;transform:translateX(-50%)}.portal-tooltip.tip-below:after{border-bottom-color:#111827;top:-10px;transform:translateX(-50%)}.btn-action[title]:hover:after,[data-tooltip]:hover:after{animation:tooltipFadeIn .12s ease-out;background:#111827;border-radius:6px;bottom:calc(100% + 6px);box-shadow:0 4px 10px -2px #0000002e;color:#fff;content:attr(title);font-size:.72rem;font-weight:500;left:50%;padding:.3rem .55rem;pointer-events:none;position:absolute;transform:translateX(-50%);white-space:nowrap;z-index:50}[data-tooltip]:hover:after{content:attr(data-tooltip)}.btn-action[title]:hover:before,[data-tooltip]:hover:before{animation:tooltipFadeIn .12s ease-out;border:5px solid #0000;border-top-color:#111827;bottom:calc(100% + 1px);content:"";left:50%;pointer-events:none;position:absolute;transform:translateX(-50%);z-index:50}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(2px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.btn-action:hover{transform:scale(1.15)}.btn-action.btn-edit{color:#3b82f6}.btn-action.btn-edit:hover{background:#eff6ff!important;color:#2563eb}.btn-action.btn-view{color:#6366f1}.btn-action.btn-view:hover{background:#eef2ff!important;color:#4f46e5}.btn-action.btn-info{color:#0891b2}.btn-action.btn-info:hover{background:#ecfeff!important;color:#0e7490}.btn-action.btn-tag{color:#7c3aed}.btn-action.btn-tag:hover{background:#f5f3ff!important;color:#6d28d9}.btn-action.btn-primary{color:#3b82f6}.btn-action.btn-primary:hover{background:#eff6ff!important;color:#2563eb}.btn-action.btn-success{color:#10b981}.btn-action.btn-success:hover{background:#ecfdf5!important;color:#059669}.btn-action.btn-warning{color:#f59e0b}.btn-action.btn-warning:hover{background:#fffbeb!important;color:#d97706}.btn-action.btn-danger{color:#ef4444}.btn-action.btn-danger:hover{background:#fef2f2!important;color:#dc2626}.btn-action.btn-secondary{color:#6b7280}.btn-action.btn-secondary:hover{background:#f3f4f6!important;color:#374151}.btn-action.btn-delete{color:#ef4444}.btn-action.btn-delete:hover{background:#fef2f2!important;color:#dc2626}.action-buttons{justify-content:flex-start}.role-select{background:#fff;border:1px solid #ced4da;border-radius:.375rem;cursor:pointer;font-size:.75rem;padding:.375rem .5rem}.role-select:focus{border-color:#000;border-color:var(--primary-color);outline:none}.current-user-badge{background:#e3f2fd;border:1px solid #bbdefb;border-radius:.375rem;color:#1976d2;font-size:.75rem;font-weight:600;padding:.375rem .75rem}.login-footer .branding p{color:#6c757d;color:var(--secondary-color);font-size:.9rem;margin:0}.login-footer .branding a{color:#000;color:var(--primary-color);font-weight:600;text-decoration:none;transition:color .3s ease}.login-footer .branding a:hover{color:#333;color:var(--primary-dark);text-decoration:underline}.error-message{background:#fee;border:1px solid #fcc;border-radius:0;color:#c33;font-size:.9rem;margin-bottom:1rem;padding:.8rem;text-align:center}.login-title{color:#000;color:var(--primary-color);font-size:2rem;font-weight:600;margin-bottom:.5rem}.login-subtitle{color:#6c757d;color:var(--secondary-color);font-size:1.1rem;margin-bottom:2rem}.settings-tabs{background:linear-gradient(135deg,#f8f9fa,#e9ecef);box-shadow:0 4px 12px #0000001a;display:flex;gap:.5rem;margin-bottom:2rem;padding:.5rem}.settings-tab{background:#0000;border:none;color:#6c757d;cursor:pointer;font-size:.95rem;font-weight:500;min-width:180px;padding:1rem 1.5rem;position:relative;text-align:center;transition:all .3s ease}.settings-tab:before{background:linear-gradient(135deg,#8cc63f1a,#6aa23c1a);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease;z-index:0}.settings-tab span{position:relative;z-index:1}.settings-tab:hover{box-shadow:0 4px 8px #0000001a;color:#495057;transform:translateY(-2px)}.settings-tab:hover:before{opacity:1}.settings-tab.active{background:linear-gradient(135deg,#000,#333);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);box-shadow:0 6px 16px #8cc63f4d;color:#fff;font-weight:600;transform:translateY(-2px)}.settings-tab.active:before{opacity:0}.settings-tab-content{background:#fff;box-shadow:0 2px 8px #0000000d;min-height:400px;padding:1rem}.exports-container{padding:0}.export-form{background:linear-gradient(135deg,#f8f9fa,#fff);border:1px solid #e9ecef;box-shadow:0 4px 12px #0000000d;margin-top:1rem;padding:2rem}.export-options{display:flex;flex-direction:column;gap:2rem;margin-bottom:2rem}.radio-label{align-items:center;color:#495057;cursor:pointer;display:flex;font-weight:500;margin-bottom:1rem;padding-left:2rem;position:relative}.radio-label input[type=radio]{cursor:pointer;opacity:0;position:absolute}.radio-custom{background-color:#fff;border:2px solid #dee2e6;border-radius:50%;height:20px;left:0;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s ease;width:20px}.radio-label:hover .radio-custom{border-color:#000;border-color:var(--primary-color);box-shadow:0 0 0 3px #8cc63f1a}.radio-label input[type=radio]:checked~.radio-custom{background-color:#000;background-color:var(--primary-color);border-color:#000;border-color:var(--primary-color)}.radio-custom:after{background:#fff;border-radius:50%;content:"";display:none;height:6px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:6px}.radio-label input[type=radio]:checked~.radio-custom:after{display:block}.period-inputs{align-items:center;background:#8cc63f0d;border-left:4px solid #000;border-left:4px solid var(--primary-color);display:flex;gap:1rem;margin-top:1rem;padding:1rem}.period-inputs input{border:1px solid #ced4da;flex:1 1;padding:.5rem;transition:border-color .2s ease}.period-inputs input:focus{border-color:#000;border-color:var(--primary-color);box-shadow:0 0 0 2px #8cc63f33}.period-inputs input:disabled{background-color:#f8f9fa;opacity:.6}.period-inputs span{color:#6c757d;font-weight:500}.year-input{background:#8cc63f0d;border-left:4px solid #000;border-left:4px solid var(--primary-color);margin-top:1rem;padding:1rem}.year-input select{border:1px solid #ced4da;font-size:1rem;max-width:200px;padding:.5rem;transition:border-color .2s ease;width:100%}.year-input select:focus{border-color:#000;border-color:var(--primary-color);box-shadow:0 0 0 2px #8cc63f33}.year-input select:disabled{background-color:#f8f9fa;opacity:.6}.export-form .btn-primary{background:linear-gradient(135deg,#000,#333);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);border:none;box-shadow:0 4px 12px #8cc63f4d;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.export-form .btn-primary:hover{box-shadow:0 6px 16px #8cc63f66;transform:translateY(-2px)}.password-change-notice{background:#fff3cd;border:1px solid #ffeeba;border-radius:6px;color:#856404;font-size:.95rem;line-height:1.4;margin-bottom:1.5rem;padding:1rem}.password-requirements{background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;margin-top:1rem;padding:.75rem}.password-requirements small{color:#6c757d;font-size:.875rem;line-height:1.4}.app-header{background:linear-gradient(135deg,#000,#333);background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);color:#fff;padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;width:100%;z-index:1000}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.header-title h1{font-size:1.8rem;font-weight:600;margin-bottom:.25rem}.header-title p{font-size:.95rem;opacity:.9}.header-actions{align-items:center;display:flex;gap:.5rem}.mobile-menu-toggle{background:#fff3;border:2px solid #ffffff4d;border-radius:0;display:none;padding:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.back-to-top,.mobile-menu-toggle{color:#fff;cursor:pointer;font-size:1.2rem}.back-to-top{background:#000;background:var(--primary-color);border:none;border-radius:50%;bottom:2rem;box-shadow:0 8px 30px #00000026;box-shadow:var(--shadow-hover);height:50px;opacity:0;position:fixed;right:2rem;transform:translateY(10px);transition:all .3s ease;visibility:hidden;width:50px;z-index:1000}.back-to-top.visible{opacity:1;transform:translateY(0);visibility:visible}.back-to-top:hover{background:#333;background:var(--primary-dark);box-shadow:0 8px 20px #8cc63f66;transform:translateY(-2px)}.mobile-pdf-modal{background:#fff;bottom:0;display:flex;flex-direction:column;left:0;position:fixed;right:0;top:0;z-index:9999}.mobile-pdf-header{align-items:center;background:#000;background:var(--primary-color);box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:1rem}.mobile-pdf-header h3{font-size:1.2rem;margin:0}.mobile-pdf-actions{display:flex;gap:.5rem}.mobile-pdf-close,.mobile-pdf-print{background:#fff3;border:1px solid #ffffff4d;border-radius:0;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background-color .3s;white-space:nowrap}.mobile-pdf-close:hover,.mobile-pdf-print:hover{background:#ffffff4d}.mobile-pdf-print{background:#ffffff26}.mobile-pdf-print:hover{background:#ffffff40}.mobile-pdf-content{background:#f5f5f5;flex:1 1;overflow:hidden}.header-user-info{align-items:center;display:flex;font-size:.9rem;gap:.5rem}.header-btn{background:#ffffff26;border:1px solid #ffffff4d;border-radius:0;color:#fff;cursor:pointer;font-size:.85rem;padding:.4rem .8rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);white-space:nowrap}.header-btn:hover{background:#ffffff40}.onboarding-help-btn{align-items:center;background:#fff3;border:2px solid #fff6;border-radius:50%;display:flex;font-size:1.2rem;height:36px;justify-content:center;padding:0;transition:all .3s;width:36px}.onboarding-help-btn:hover{background:#ffffff59;box-shadow:0 4px 12px #0003;transform:rotate(15deg) scale(1.1)}@media (max-width:992px){.header-actions{gap:.3rem}.header-user-info{font-size:.8rem}.header-btn{font-size:.75rem;padding:.3rem .6rem}.header-btn-label{display:none}}@media (max-width:576px){.header-content{padding:0 .75rem!important}.header-title h1{font-size:1.2rem!important}.header-title p{font-size:.75rem!important}.header-actions{gap:.25rem}.header-user-info{font-size:.75rem}.header-btn{align-items:center;display:flex;font-size:1rem;justify-content:center;min-height:34px;min-width:34px;padding:.3rem .5rem}.header-btn-label{display:none}.onboarding-help-btn{font-size:1rem;height:34px;width:34px}}.desktop-header-menu{align-items:center;display:flex;gap:.5rem}.mobile-header-toggle{display:none}@media (max-width:992px){.desktop-header-menu{display:none}.mobile-header-toggle{background:#fff3;border:1px solid #ffffff4d;border-radius:0;color:#fff;cursor:pointer;display:block;font-size:1rem;padding:.5rem}}.mobile-menu-toggle:hover{background:#ffffff4d}.btn-logout{background:#fff3;border:2px solid #ffffff4d;border-radius:0;color:#fff;font-weight:500;padding:.5rem 1rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.btn-logout:hover{background:#ffffff4d;border-color:#ffffff80}.btn-settings{background-color:#6c757d;border:none;border-radius:0;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .3s}.btn-settings:hover{background-color:#5a6268}.nav-container{background:#fff;border-bottom:1px solid #e5e7eb;padding:.5rem 0;position:-webkit-sticky;position:sticky;top:80px;z-index:100}.nav-tabs{align-items:center;display:flex;gap:0;justify-content:center;margin:0 auto;max-width:1200px;padding:0 2rem}.nav-tabs button{background:#0000;border:none;border-bottom:2px solid #0000;border-radius:0;color:#6b7280;cursor:pointer;font-size:.875rem;font-weight:500;letter-spacing:normal;padding:.75rem 1.5rem;position:relative;text-transform:none;transition:all .2s ease;white-space:nowrap}.nav-tabs button:hover{background:#f9fafb;border-bottom-color:#d1d5db;color:#374151}.nav-tabs button.active{background:#0000;border-bottom-color:#000;border-bottom-color:var(--primary-color);color:#000;color:var(--primary-color);font-weight:600}.nav-tabs button.active:hover{background:#f9fafb;border-bottom-color:#333;border-bottom-color:var(--primary-dark);color:#333;color:var(--primary-dark)}.main-content{flex:1 1;margin:0 auto;max-width:1200px;padding:2rem;width:100%}.section-header{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid #e9ecef;border-bottom:2px solid var(--border-color);border-radius:0;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:2rem}.section-subtitle{color:#6b7280;font-size:.875rem;font-style:italic;font-weight:400;margin:.25rem 0 1rem}.section-header h2{color:#343a40;color:var(--dark-color);font-size:1.5rem;font-weight:600;margin:0;padding-left:1rem;position:relative}.section-header h2:before{background:#000;background:var(--primary-color);border-radius:0;content:"";height:24px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:4px}.header-buttons{flex-wrap:wrap;gap:.75rem}.dashboard-header{background:linear-gradient(135deg,#000,#333);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);border-radius:0;box-shadow:0 4px 12px #8cc63f4d;color:#fff;margin-bottom:2rem;padding:2rem;text-align:center}.dashboard-header h2{font-size:2rem;font-weight:800;margin:0;text-shadow:0 2px 4px #0003}.user-info{font-size:.9rem;margin-top:.5rem;opacity:.9}.btn.btn-primary{background:linear-gradient(135deg,#000,#333);background:linear-gradient(135deg,var(--primary-color) 0,var(--primary-dark) 100%);border:none;box-shadow:0 2px 8px #8cc63f4d;font-weight:600;letter-spacing:.5px;text-transform:uppercase;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease}.btn.btn-primary:hover{background:linear-gradient(135deg,#333,#000);background:linear-gradient(135deg,var(--primary-dark) 0,var(--primary-color) 100%);box-shadow:0 4px 12px #8cc63f66;filter:brightness(.95);transform:translateY(-1px)}.btn.btn-secondary{background:linear-gradient(135deg,#6c757d,#5a6268);border:none;box-shadow:0 2px 8px #6c757d4d;color:#fff;font-weight:600;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease}.btn.btn-secondary:hover{background:linear-gradient(135deg,#5a6268,#6c757d);box-shadow:0 4px 12px #6c757d66;filter:brightness(.95);transform:translateY(-1px)}.recent-orders-section{background:#fff;border:1px solid #dee2e6;border-radius:0;box-shadow:0 2px 8px #00000014;margin-top:2rem;overflow:hidden}.section-header-mini{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:1.5rem}.section-header-mini h3{color:#343a40;font-size:1.25rem;font-weight:700;margin:0;padding-left:1rem;position:relative}.section-header-mini h3:before{background:#000;background:var(--primary-color);border-radius:0;content:"";height:20px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:4px}.orders-count{align-items:center;background:#fff;border:1px solid #dee2e6;border-radius:0;color:#6c757d;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem}.recent-orders-section .table-container{border:none;border-radius:0;box-shadow:none;margin:0}.recent-orders-section table{border-radius:0;margin:0}@media (max-width:768px){.section-header-mini{align-items:stretch;flex-direction:column;gap:1rem}.orders-count{text-align:center}}.header-buttons{align-items:center;display:flex;gap:10px}.btn{align-items:center;border:none;border-radius:0;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:500;gap:.5rem;line-height:1.2;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.btn-primary{background:#000;background:var(--primary-color);color:#fff}.btn-primary:hover{background:#333;background:var(--primary-dark)}.btn-secondary{background:#6c757d;background:var(--secondary-color);color:#fff}.btn-secondary:hover{background:#5a6268}.btn-danger{background:#dc3545;background:var(--danger-color);color:#fff}.btn-danger:hover{background:#c82333}.btn-view{background:#ff9800;color:#fff}.btn-view:hover{background:#e68900}.btn-success{background:#28a745;color:#fff}.btn-success:hover{background:#218838}.btn-sm{font-size:.875rem;padding:.5rem 1rem}.btn-info{background-color:#17a2b8;border:none;border-radius:4px;cursor:pointer;font-size:12px;margin:0 2px;padding:4px 8px}.btn-info:hover{background-color:#138496}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border-radius:0;border-radius:var(--border-radius);box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);display:flex;gap:1rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.stat-card-clickable{cursor:pointer}.stat-card-clickable:hover{background:#f8f9fa;transform:translateY(-5px)}.stat-card-clickable:hover,.stat-card:hover{box-shadow:0 8px 30px #00000026;box-shadow:var(--shadow-hover)}.stat-icon{font-size:3rem;opacity:.8}.stat-content h3{color:#6c757d;color:var(--secondary-color);font-size:.95rem;font-weight:500;margin-bottom:.5rem}.stat-number{color:#000;color:var(--primary-color);font-size:2rem;font-weight:700;margin:0}.table-container{background:#fff;box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);margin-bottom:2rem;overflow:visible}.table-container,.table-container>table{border-radius:0;border-radius:var(--border-radius)}.table-container>table{overflow:hidden}table{border-collapse:collapse;width:100%}td,th{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);padding:1rem;text-align:left}th{background:#f8f9fa;background:var(--light-color);color:#343a40;color:var(--dark-color);font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}tr:hover{background:#8cc63f0d}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:0;border-radius:var(--border-radius);box-shadow:0 8px 30px #00000026;box-shadow:var(--shadow-hover);max-height:90vh;max-width:500px;overflow-y:auto;padding:2rem;width:100%}.modal-large{max-width:800px}.modal-header{border-bottom:1px solid #dee2e6;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.modal-close,.modal-header{align-items:center;display:flex}.modal-close{background:none;border:none;border-radius:50%;color:#6c757d;cursor:pointer;font-size:1.5rem;height:30px;justify-content:center;padding:0;transition:background-color .3s;width:30px}.modal-close:hover{background-color:#f8f9fa;color:#dc3545}.form-group{margin-bottom:1.5rem}.form-group label{color:#343a40;color:var(--dark-color);display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:2px solid #e9ecef;border:2px solid var(--border-color);border-radius:0;font-family:inherit;font-size:1rem;padding:.75rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#000;border-color:var(--primary-color);box-shadow:0 0 0 3px #8cc63f1a;outline:none}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.form-text{color:#6c757d;font-size:.875rem;margin-top:.25rem}.settings-section{margin-bottom:2rem}.settings-section h3{align-items:center;border-bottom:2px solid #e9ecef;border-bottom:2px solid var(--border-color);color:#343a40;color:var(--dark-color);display:flex;font-size:1.25rem;font-weight:600;gap:.5rem;margin-bottom:1.5rem;margin-top:2rem;padding-bottom:.75rem}.settings-section:first-child h3{margin-top:0}.checkbox-label{align-items:center;color:#343a40;color:var(--dark-color);cursor:pointer;display:flex!important;font-weight:500;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{accent-color:#000;accent-color:var(--primary-color);margin-right:.75rem;transform:scale(1.2);width:auto!important}.checkbox-label:hover{color:#000;color:var(--primary-color)}.save-price-option{background:#ffc10714;border-left:3px solid #ffc107;border-left:3px solid var(--warning-color);border-radius:4px;margin-bottom:.75rem;margin-top:.75rem;padding:.75rem 1rem}.save-price-option .checkbox-label{align-items:center;display:flex;font-size:.875rem;font-weight:400;gap:.5rem;margin:0}.save-price-option .checkbox-label input[type=checkbox]{flex-shrink:0;margin:0}.save-price-option .checkbox-label span{color:#343a40;color:var(--dark-color);line-height:1.5}.status{border-radius:0;font-size:.8rem;font-weight:500;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.status.brouillon{background:#6c757d33;color:#495057}.status.en_cours{background:#ffc10733;color:#856404}.status.livre{background:#28a74533;color:#155724}.status.facture{background:#17a2b833;color:#0c5460}.status.annule{background:#dc354533;color:#721c24}.status.active{background:#28a74533;color:#155724}.status.inactive{background:#dc354533;color:#721c24}.type-badge{border-radius:4px;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.type-badge.GMS{background:#ffc10733;color:#856404}.type-badge.boutique{background:#17a2b833;color:#0c5460}.type-badge.particulier{background:#28a74533;color:#155724}.role-badge{border-radius:4px;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.role-badge.admin{background:#dc354533;color:#721c24}.role-badge.user{background:#6c757d33;color:#495057}.role-badge.comptable{background:#28a74533;color:#155724}.btn-outline{background:#0000;border:1px solid #6c757d;border-radius:4px;color:#6c757d;cursor:pointer;font-size:.875rem;padding:.375rem .75rem;transition:all .2s ease}.btn-outline:hover{background:#6c757d;color:#fff}.form-select-sm{background:#fff;border:1px solid #ced4da;border-radius:4px;font-size:.875rem;margin:0 .25rem;min-width:120px;padding:.25rem .5rem}.form-select-sm:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40;outline:0}.clients table td:nth-child(4),.clients table td:nth-child(6),.clients table th:nth-child(4),.clients table th:nth-child(6){white-space:nowrap}.clients table td strong{display:inline-block;white-space:nowrap}.clients table th:nth-child(7){text-align:center}.produits .action-buttons{align-items:stretch;display:flex;flex-direction:column;gap:.25rem}.produits .action-buttons .btn-action{font-size:.8rem;padding:.25rem .5rem;white-space:nowrap}.commandes table th:nth-child(8){text-align:center}.commandes table td:nth-child(2),.commandes table td:nth-child(6),.commandes table th:nth-child(2),.commandes table th:nth-child(6){white-space:nowrap}.commandes .action-buttons{align-items:center;display:flex;flex-direction:row;gap:2px;justify-content:center}.commandes .action-buttons .btn-action{height:32px;width:32px}.users .action-buttons{align-items:center;display:flex;flex-wrap:nowrap;gap:4px}.users .action-buttons .btn{font-size:.875rem;padding:.375rem .75rem}.current-user-badge{background:#28a74533;border-radius:4px;color:#155724;font-size:.875rem;font-weight:500;padding:.25rem .5rem}.modal-small{margin:2rem auto;max-width:500px}.password-reset-info{padding:1rem 0}.password-display{align-items:center;background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;display:flex;gap:.75rem;margin:.75rem 0;padding:1rem}.password-code{background:#fff;border:1px solid #ced4da;border-radius:4px;color:#212529;flex:1 1;font-family:Courier New,monospace;font-size:1.1rem;font-weight:700;padding:.5rem;word-break:break-all}.btn-copy{font-size:.875rem;padding:.5rem 1rem;white-space:nowrap}.password-warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;color:#856404;font-size:.9rem;margin-top:1rem;padding:.75rem}.bio-badge{background:linear-gradient(135deg,#28a745,#20c997);box-shadow:0 2px 4px #28a7454d}.bio-badge,.fin-saison-badge{border-radius:4px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;margin-left:.5rem;padding:.2rem .4rem;text-transform:uppercase}.fin-saison-badge{background:linear-gradient(135deg,#6c757d,#495057);box-shadow:0 2px 4px #6c757d4d}.fin-de-saison{background-color:#f8f9fa;opacity:.6}.fin-de-saison td{color:#6c757d;text-decoration:line-through}.stock-alerts{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:0;margin-bottom:20px;padding:15px}.stock-alerts h3{color:#856404;margin:0 0 10px}.alerts-container{display:flex;flex-direction:column;gap:8px}.alert{align-items:center;border-radius:4px;display:flex;font-size:14px;gap:8px;padding:8px 12px}.alert.faible{background-color:#fff3cd;border:1px solid #ffeaa7;color:#856404}.alert.critique{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.stock-form-container{display:flex;flex-direction:column;gap:15px}.produit-stock-ligne{grid-gap:15px;align-items:end;background-color:#f8f9fa;border:1px solid #ddd;border-radius:0;display:grid;gap:15px;grid-template-columns:2fr 1fr;padding:15px}.stock-history-container{margin-bottom:15px;max-height:400px;overflow-y:auto}.stock-history-table{border-collapse:collapse;font-size:14px;width:100%}.stock-history-table td,.stock-history-table th{border-bottom:1px solid #dee2e6;padding:8px;text-align:left}.stock-history-table th{background-color:#f8f9fa;color:#495057;font-weight:600}.mouvement-type{border-radius:0;font-size:12px;font-weight:500;padding:2px 6px}.mouvement-type.entree{background-color:#d4edda;color:#155724}.mouvement-type.sortie{background-color:#f8d7da;color:#721c24}.critical-stock{background-color:#f8d7da!important;color:#721c24!important;font-weight:700}.low-stock{background-color:#fff3cd!important;color:#856404!important;font-weight:500}.stock-warning{font-size:14px;margin-left:5px}.btn-action{align-items:center;border:1px solid;border-radius:.375rem;cursor:pointer;display:flex;font-size:.8rem;font-weight:500;gap:.25rem;height:32px;justify-content:center;margin:0 .125rem;min-width:70px;padding:.375rem .75rem;text-decoration:none;transition:all .15s ease-in-out;white-space:nowrap}.client-name-clickable{color:#495057;cursor:pointer;font-weight:600;padding:.25rem 0;position:relative;text-decoration:none;transition:all .2s ease}.client-name-clickable:hover{color:#000;color:var(--primary-color);text-decoration:none;transform:translateX(2px)}.client-name-clickable:after{content:" 📊";font-size:.75em;margin-left:.5rem;opacity:0;transition:opacity .2s ease}.client-name-clickable:hover:after{opacity:1}@media (min-width:769px){.mobile-details-btn,.mobile-details-row{display:none!important}}@media (max-width:768px){.table-hide-mobile{display:none!important}.mobile-details-btn{background:#f8f9fa;border:1px solid #dee2e6;color:#495057;cursor:pointer;font-size:.75rem;margin-right:.25rem;padding:.25rem .5rem;transition:all .2s ease}.mobile-details-btn:hover{background:#e9ecef;color:#212529}.mobile-details-btn.expanded{background:#000;background:var(--primary-color);border-color:#000;border-color:var(--primary-color);color:#fff}.mobile-details-row{background:#f8f9fa;display:none}.mobile-details-row.expanded{display:table-row}.mobile-details-content{border-top:1px solid #dee2e6;padding:1rem}.mobile-details-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.mobile-detail-item{display:flex;flex-direction:column;gap:.25rem}.mobile-detail-label{color:#6c757d;font-size:.75rem;font-weight:600;text-transform:uppercase}.mobile-detail-value{color:#212529;font-size:.875rem}.table-container{overflow-x:auto}table{min-width:100%}td,th{font-size:.875rem;padding:.5rem .25rem}.action-buttons{flex-direction:row;gap:2px}.btn-action{height:28px;width:28px}}.btn-info{background:#17a2b8;border:1px solid #17a2b8;color:#fff}.btn-info:hover{background:#138496;border-color:#117a8b}.modal-extra-large{max-height:90vh;max-width:95%;overflow-y:auto;width:1400px}.client-detail-content{padding:1rem}.client-info-section{background:#f8f9fa;border:1px solid #dee2e6;margin-bottom:2rem;padding:1.5rem}.client-info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item label{color:#495057;font-size:.875rem;font-weight:600}.info-item span{color:#212529;font-size:1rem}.ca-amount{color:#28a745!important;font-size:1.1rem!important}.order-history-section,.product-stats-section{margin-bottom:2rem}.loading-message,.no-data-message{color:#6c757d;font-style:italic;padding:2rem;text-align:center}.no-data-message{background:#f8f9fa;border:1px solid #dee2e6}.produits-list-compact{display:flex;flex-direction:column;gap:.25rem}.produit-compact{background:#e9ecef;border:0;display:inline-block;font-size:.875rem;margin-bottom:.25rem;padding:.25rem .5rem}.no-products{color:#6c757d;font-style:italic}.action-buttons{flex-wrap:nowrap;gap:2px;justify-content:center}.action-buttons,.header-logo{align-items:center;display:flex}.header-logo{gap:1rem}.logo-img{max-height:60px;object-fit:contain;width:auto}.file-input{height:0;opacity:0;position:absolute;width:0}.current-logo{border:1px solid #ddd;border-radius:4px;margin-bottom:10px;max-height:100px;max-width:200px;object-fit:contain;padding:5px}.footer{background-color:#f8f9fa;border-top:1px solid #dee2e6;margin-top:2rem;padding:1rem;text-align:center}.footer a{color:#000;color:var(--primary-color);font-weight:500;text-decoration:none}.footer a:hover{text-decoration:underline}.color-input-group{align-items:center;background:#f8f9fa;border:2px solid #e9ecef;border:2px solid var(--border-color);border-radius:0;display:flex;gap:1rem;padding:1rem;transition:all .3s ease}.color-input-group:hover{background:#fff;border-color:#000;border-color:var(--primary-color)}.color-picker{border:3px solid #fff!important;border-radius:12px!important;box-shadow:0 4px 12px #00000026!important;cursor:pointer!important;height:50px!important;padding:0!important;transition:all .3s ease!important;width:80px!important}.color-picker:hover{box-shadow:0 6px 20px #0003!important;transform:scale(1.05)!important}.color-picker:focus{box-shadow:0 0 0 3px #8cc63f4d!important;outline:none!important}.color-text{background:#fff!important;border:2px solid #e9ecef!important;border-radius:8px!important;color:#343a40!important;color:var(--dark-color)!important;flex:1 1!important;font-family:Courier New,monospace!important;font-size:1rem!important;font-weight:600!important;letter-spacing:1px!important;padding:.75rem 1rem!important;text-transform:uppercase!important}.color-text:focus{border-color:#000!important;border-color:var(--primary-color)!important;box-shadow:0 0 0 3px #8cc63f1a!important;outline:none!important}.color-preview{background:#000;background:var(--primary-color);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0003;height:30px;width:30px}.form-group.color-group label{align-items:center;color:#343a40;color:var(--dark-color);display:flex;font-weight:600;gap:.5rem;margin-bottom:1rem}.notifications-container{bottom:20px;display:flex;flex-direction:column;gap:.5rem;position:fixed;right:20px;z-index:10000}.notification-toast{animation:slideIn .3s ease-out;border-radius:0;box-shadow:0 8px 30px #00000026;box-shadow:var(--shadow-hover);min-width:300px;padding:1rem 2.5rem 1rem 1rem;position:relative}.notification-toast.success{background:#28a745;background:var(--success-color);color:#fff}.notification-toast.error{background:#dc3545;background:var(--danger-color);color:#fff}.notification-toast.warning{background:#ffc107;background:var(--warning-color);color:#212529}.notification-toast.info{background:#17a2b8;background:var(--info-color);color:#fff}.notification-content{align-items:center;display:flex}.notification-message{flex:1 1;line-height:1.4}.notification-close{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;font-size:1.5rem;height:24px;justify-content:center;line-height:1;opacity:.7;padding:.25rem;position:absolute;right:.5rem;top:.5rem;transition:opacity .2s,transform .2s;width:24px}.notification-close:hover{opacity:1;transform:scale(1.1)}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:992px){.mobile-menu-toggle{display:block}.nav-tabs{background:#fff;border-top:1px solid #e9ecef;border-top:1px solid var(--border-color);box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);flex-direction:column;left:0;max-height:0;opacity:0;overflow:hidden;position:absolute;right:0;top:100%;transition:all .3s ease;visibility:hidden;z-index:999}.nav-tabs.mobile-open{max-height:500px;opacity:1;visibility:visible}.nav-tabs button{background:#fff;border:none;border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);border-radius:0;color:#343a40;color:var(--dark-color);min-width:auto;padding:1rem 2rem;text-align:left;transition:background-color .2s;width:100%}.nav-tabs button:hover{background-color:var(--light-bg)}.nav-tabs button.active{background-color:#000;background-color:var(--primary-color);color:#fff}.nav-tabs button:last-child{border-bottom:none}}@media (max-width:576px){.app-header{padding:.8rem 1rem}.header-title h1{font-size:1.4rem}.header-title p{font-size:.8rem}.back-to-top{bottom:1rem;font-size:1rem;height:45px;right:1rem;width:45px}.container{padding:1rem}.stats-grid{gap:1rem;grid-template-columns:1fr}.btn,.table-container{font-size:.85rem}.btn{padding:.5rem .8rem}.header-actions{position:relative}.mobile-header-toggle{background:#fff3;border:1px solid #ffffff4d;border-radius:0;color:#fff;cursor:pointer;display:block;font-size:1rem;padding:.5rem}.app-header{padding:.8rem 1rem}.header-title h1{font-size:1.4rem}.header-title p{font-size:.8rem}.back-to-top{bottom:1rem;font-size:1rem;height:45px;right:1rem;width:45px}.container{padding:1rem}.stats-grid{gap:1rem}.btn,.table-container{font-size:.85rem}.btn{padding:.5rem .8rem}.header-actions{position:relative}.mobile-header-toggle{background:#fff3;border:1px solid #ffffff4d;border-radius:0;color:#fff;cursor:pointer;display:block;font-size:1rem;padding:.5rem}.main-content{padding:1rem}.section-header{align-items:stretch;flex-direction:column;gap:1rem}.stats-grid{grid-template-columns:1fr}.modal{margin:1rem;padding:1.5rem}.form-actions{flex-direction:column}.btn{justify-content:center}.table-container{overflow-x:auto}.action-buttons{flex-direction:row}.header-logo{flex-direction:column;gap:.5rem;text-align:center}.header-actions{gap:.5rem}}.commande-section{background:#f8f9fa;border:2px solid #e9ecef;border-radius:0;margin-bottom:2rem;padding:1.5rem}.commande-client{background:linear-gradient(135deg,#8cc63f0d,#8cc63f05);border-color:#000;border-color:var(--primary-color)}.commande-produits{background:linear-gradient(135deg,#17a2b80d,#17a2b805);border-color:#17a2b8}.section-title{align-items:center;border-bottom:2px solid #0000001a;color:#343a40;color:var(--dark-color);display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem}.produit-ligne{grid-gap:1rem;align-items:end;background:#fff;border:1px solid #dee2e6;border-radius:0;box-shadow:0 2px 4px #0000000d;display:grid;gap:1rem;grid-template-columns:2fr 1fr 1fr;margin-bottom:1rem;padding:1rem;position:relative}.produit-ligne-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;grid-column:1/-1;justify-content:space-between;margin-bottom:1rem;padding-bottom:.5rem}.produit-ligne-header h5{color:#343a40;color:var(--dark-color);font-size:1rem;font-weight:600;margin:0}.btn-remove-line{background:#dc3545;border:1px solid #dc3545;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;height:auto;min-width:auto;padding:.25rem .5rem;transition:all .2s ease}.btn-remove-line:hover{background:#c82333;border-color:#bd2130;transform:scale(1.05)}.prix-info{border-top:1px solid #e9ecef;color:#6c757d;font-size:.875rem;grid-column:1/-1;margin-top:.5rem;padding-top:.5rem}.filters-section{background:#fff;border-radius:0;border-radius:var(--border-radius);box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);margin-bottom:2rem;padding:1.5rem}.filters{grid-gap:1.5rem;align-items:end;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 2px 8px #00000014;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem;padding:1.5rem}.filters .filter-group{display:flex;flex-direction:column;gap:.5rem;position:relative}.filters .filter-group label{color:var(--text-primary);font-size:.875rem;font-weight:600;margin-bottom:.25rem}.filters .filter-group input,.filters .filter-group select{background:#fff;border:2px solid #e9ecef;border:2px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 1px 3px #0000001a;color:var(--text-primary);font-size:.875rem;padding:.75rem 1rem;transition:all .3s ease;width:100%}.filters .filter-group input:focus,.filters .filter-group select:focus{border-color:#000;border-color:var(--primary-color);box-shadow:0 0 0 3px #8cc63f1a,0 2px 8px #00000026;outline:none;transform:translateY(-1px)}.filters .filter-group input::placeholder{color:var(--text-muted);font-style:italic}.filters-row{grid-gap:1rem;align-items:end;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-group{display:flex;flex-direction:column}.filter-group label{color:#343a40;color:var(--dark-color);font-size:.875rem;font-weight:500;margin-bottom:.5rem}.filter-group .btn{align-self:flex-start;font-size:.875rem;height:auto;padding:.6rem 1rem;white-space:nowrap;width:-webkit-fit-content;width:fit-content}.filter-input,.filter-select{border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:0;font-size:.875rem;padding:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.filter-input{padding:.35rem}.filter-input:focus,.filter-select:focus,.search-input:focus{border-color:#000;border-color:var(--primary-color);box-shadow:0 0 0 2px #8cc63f1a;outline:none}.search-group{flex:1 1;max-width:400px;min-width:250px}.search-input{background:#f8f9fa;border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:0;font-size:.875rem;padding:.35rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.search-input::placeholder{color:#6c757d;font-style:italic}.search-highlight{background-color:#8cc63f33;border-radius:3px;padding:.1rem .2rem}@media (min-width:1400px){.filters-row{grid-template-columns:400px 250px 200px 150px}.search-group{max-width:400px}}@media (max-width:600px){td,th{font-size:.875rem;padding:.5rem}.btn-action{height:28px;min-width:28px;padding:0;width:28px}}.pagination-container{align-items:center;background:#fff;border-radius:0;border-radius:var(--border-radius);box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-top:1rem;padding:1rem}.pagination-info{color:#6c757d;color:var(--secondary-color);font-size:.9rem;font-weight:500}.pagination-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.items-per-page{align-items:center;color:#343a40;color:var(--dark-color);display:flex;font-size:.9rem;gap:.5rem}.items-per-page label{font-weight:500;margin:0}.items-per-page select{background:#fff;border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:.9rem;padding:.25rem .5rem}.items-per-page select:focus{border-color:#000;border-color:var(--primary-color);box-shadow:0 0 0 2px #8cc63f1a;outline:none}.page-navigation{align-items:center;display:flex;gap:.5rem}.page-info{color:#343a40;color:var(--dark-color);font-size:.9rem;font-weight:500;margin:0 .5rem}@media (max-width:768px){.pagination-container{align-items:stretch;flex-direction:column;gap:.75rem}.pagination-info{text-align:center}.pagination-controls{flex-direction:column;gap:.75rem}.page-navigation,.pagination-controls{justify-content:center}}.comptabilite{padding:1rem}.comptabilite .section-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.comptabilite .section-header h2{color:#343a40;color:var(--dark-color);font-size:1.5rem;margin:0}.comptabilite .header-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.comptabilite-dashboard{margin-bottom:2rem}.kpi-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:1rem}.kpi-grid-montants{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.kpi-card{align-items:center;background:#fff;border-left:4px solid #000;border-left:4px solid var(--primary-color);border-radius:0;border-radius:var(--border-radius);box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);display:flex;gap:1rem;padding:1.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.kpi-card:hover{box-shadow:0 8px 30px #00000026;box-shadow:var(--shadow-hover);transform:translateY(-2px)}.kpi-card.kpi-warning{border-left-color:#ffc107;border-left-color:var(--warning-color)}.kpi-card.kpi-danger{border-left-color:#dc3545;border-left-color:var(--danger-color)}.kpi-card.kpi-success{border-left-color:#28a745;border-left-color:var(--success-color)}.kpi-icon{font-size:2rem}.kpi-content{display:flex;flex-direction:column}.kpi-value{color:#343a40;color:var(--dark-color);font-size:1.75rem;font-weight:700}.kpi-label{color:#6c757d;color:var(--secondary-color);font-size:.85rem}.kpi-card-large{background:#fff;border-radius:0;border-radius:var(--border-radius);box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);padding:1.5rem;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.kpi-card-large:hover{box-shadow:0 8px 30px #00000026;box-shadow:var(--shadow-hover);transform:translateY(-2px)}.kpi-card-large.kpi-success{background:linear-gradient(135deg,#d4edda,#c3e6cb)}.kpi-card-large.kpi-warning{background:linear-gradient(135deg,#fff3cd,#ffeeba)}.kpi-value-large{color:#343a40;color:var(--dark-color);display:block;font-size:1.5rem;font-weight:700;margin-top:.5rem}.comptabilite .filters-section{background:#fff;border-radius:0;border-radius:var(--border-radius);box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);margin-bottom:1rem;padding:1rem}.comptabilite .filters-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1rem}.comptabilite .filter-group{display:flex;flex-direction:column;gap:.25rem;min-width:150px}.comptabilite .filter-group.search-group{flex:1 1;min-width:200px}.comptabilite .filter-group label{color:#6c757d;color:var(--secondary-color);font-size:.85rem;font-weight:500}.comptabilite .filter-select,.comptabilite .search-input{border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:0;border-radius:var(--border-radius);font-size:.9rem;padding:.5rem .75rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.comptabilite .filter-select:focus,.comptabilite .search-input:focus{border-color:#000;border-color:var(--primary-color);box-shadow:0 0 0 2px #0000001a;outline:none}.comptabilite .checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem}.comptabilite .table-container{background:#fff;border-radius:0;border-radius:var(--border-radius);box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);overflow:visible}.comptabilite table{border-collapse:collapse;width:100%}.comptabilite td,.comptabilite th{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);padding:.75rem 1rem;text-align:left}.comptabilite th{color:#6c757d;color:var(--secondary-color);font-size:.85rem;font-weight:600;text-transform:uppercase}.comptabilite th,.comptabilite tr:hover{background:#f8f9fa;background:var(--light-color)}.comptabilite tr.row-en-retard{background:#fff5f5}.comptabilite tr.row-en-retard:hover{background:#ffe8e8}.statut-badge{border-radius:20px;display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.statut-non-payee{background:#f8d7da;color:#721c24}.statut-en-attente{background:#fff3cd;color:#856404}.statut-relancee{background:#d1ecf1;color:#0c5460}.statut-payee{background:#d4edda;color:#155724}.statut-en-litige{background:#d6d8d9;color:#383d41}.retard-badge{background:#dc3545;background:var(--danger-color);border-radius:20px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;padding:.2rem .5rem}.montant-paye{color:#28a745;color:var(--success-color);font-weight:500}.montant-reste{color:#dc3545;color:var(--danger-color);font-weight:600}.comptabilite .action-buttons{align-items:center;display:flex;flex-wrap:nowrap;gap:2px}.comptabilite .btn-action{border:none;border-radius:8px;cursor:pointer;height:32px;padding:0;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:32px}.comptabilite .btn-action.btn-success{background:#0000;color:#10b981}.comptabilite .btn-action.btn-success:hover{background:#ecfdf5}.comptabilite .btn-action.btn-warning{background:#0000;color:#f59e0b}.comptabilite .btn-action.btn-warning:hover{background:#fffbeb}.comptabilite .statut-select{background:#fff;border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:0;border-radius:var(--border-radius);cursor:pointer;font-size:.8rem;padding:.35rem .5rem}.comptabilite .modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.comptabilite .modal{background:#fff;border-radius:0;border-radius:var(--border-radius);box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.comptabilite .modal.modal-large{max-width:800px}.comptabilite .modal-header{align-items:center;background:#f8f9fa;background:var(--light-color);border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem 1.5rem}.comptabilite .modal-header h3{font-size:1.1rem;margin:0}.comptabilite .modal-close{background:none;border:none;color:#6c757d;color:var(--secondary-color);cursor:pointer;font-size:1.5rem;line-height:1}.comptabilite .modal-close:hover{color:#dc3545;color:var(--danger-color)}.comptabilite .modal-info{background:#f8f9fa;background:var(--light-color);border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color);padding:1rem 1.5rem}.comptabilite .modal-info p{font-size:.9rem;margin:.25rem 0}.comptabilite .modal .form-group,.comptabilite .modal form{padding:0 1.5rem}.comptabilite .modal .form-group{margin:1rem 0;padding:0}.comptabilite .modal .form-group label{display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.comptabilite .modal .form-group input,.comptabilite .modal .form-group select,.comptabilite .modal .form-group textarea{border:1px solid #e9ecef;border:1px solid var(--border-color);border-radius:0;border-radius:var(--border-radius);font-size:.9rem;padding:.5rem .75rem;width:100%}.comptabilite .modal .form-group textarea{min-height:80px;resize:vertical}.comptabilite .form-actions{background:#f8f9fa;background:var(--light-color);border-top:1px solid #e9ecef;border-top:1px solid var(--border-color);display:flex;gap:.5rem;justify-content:flex-end;padding:1rem 1.5rem}@media (max-width:768px){.comptabilite .section-header{align-items:flex-start;flex-direction:column}.comptabilite .header-buttons{width:100%}.comptabilite .header-buttons button{flex:1 1;text-align:center}.kpi-grid{grid-template-columns:repeat(2,1fr)}.comptabilite .filters-row{flex-direction:column}.comptabilite .filter-group{width:100%}.comptabilite .action-buttons{flex-direction:row}.comptabilite .btn-action{height:28px;width:28px}}.statut-non-envoyee{background:#e2e3e5;color:#383d41}.comptabilite-v2{margin:0 auto;max-width:1400px;padding:1.25rem 1.5rem}.comptabilite-v2 .cpt-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.comptabilite-v2 .cpt-header-left h2{color:#111827;font-size:1.6rem;font-weight:700;letter-spacing:-.02em;margin:0}.comptabilite-v2 .cpt-subtitle{color:#6b7280;font-size:.9rem;margin:.25rem 0 0}.comptabilite-v2 .cpt-header-actions{display:flex;flex-wrap:wrap;gap:.5rem}.comptabilite-v2 .cpt-btn-OBSOLETE{align-items:center;display:inline-flex;gap:.5rem}.comptabilite-v2 .cpt-btn-badge{background:#ffffff40;border-radius:999px;font-size:.75rem;font-weight:600;margin-left:.25rem;padding:.1rem .45rem}.comptabilite-v2 .cpt-hero{margin-bottom:1.75rem}.comptabilite-v2 .cpt-hero-cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:1rem}.comptabilite-v2 .cpt-stat-card{align-items:flex-start;background:#fff;border:1px solid #e5e7eb;border-radius:12px;display:flex;gap:.85rem;padding:1.1rem 1.15rem;transition:transform .15s ease,box-shadow .15s ease}.comptabilite-v2 .cpt-stat-card:hover{box-shadow:0 8px 20px -8px #0000001f;transform:translateY(-2px)}.comptabilite-v2 .cpt-stat-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.comptabilite-v2 .cpt-stat-icon-primary{background:#eef2ff;color:#4f46e5}.comptabilite-v2 .cpt-stat-icon-success{background:#ecfdf5;color:#059669}.comptabilite-v2 .cpt-stat-icon-warning{background:#fffbeb;color:#d97706}.comptabilite-v2 .cpt-stat-icon-info{background:#eff6ff;color:#2563eb}.comptabilite-v2 .cpt-stat-body{display:flex;flex:1 1;flex-direction:column;gap:.15rem;min-width:0}.comptabilite-v2 .cpt-stat-label{color:#6b7280;font-size:.8rem;font-weight:500}.comptabilite-v2 .cpt-stat-value{color:#111827;font-size:1.4rem;font-weight:700;letter-spacing:-.01em;line-height:1.2}.comptabilite-v2 .cpt-stat-hint{color:#9ca3af;font-size:.75rem;margin-top:.15rem}.comptabilite-v2 .cpt-stat-success{background:linear-gradient(135deg,#fff,#f0fdf4);border-color:#d1fae5}.comptabilite-v2 .cpt-stat-warning{background:linear-gradient(135deg,#fff,#fffbeb);border-color:#fde68a}.comptabilite-v2 .cpt-progress-block{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1rem 1.15rem}.comptabilite-v2 .cpt-progress-head{align-items:center;display:flex;justify-content:space-between;margin-bottom:.55rem}.comptabilite-v2 .cpt-progress-title{align-items:center;color:#374151;display:inline-flex;font-size:.85rem;font-weight:600;gap:.4rem}.comptabilite-v2 .cpt-progress-percent{color:#059669;font-size:1rem;font-weight:700}.comptabilite-v2 .cpt-progress-bar{background:#f3f4f6;border-radius:999px;height:8px;overflow:hidden}.comptabilite-v2 .cpt-progress-fill{background:linear-gradient(90deg,#10b981,#34d399);border-radius:999px;height:100%;transition:width .4s ease}.comptabilite-v2 .cpt-progress-foot{color:#6b7280;display:flex;font-size:.78rem;justify-content:space-between;margin-top:.5rem}.comptabilite-v2 .cpt-quick-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.comptabilite-v2 .cpt-chip{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:999px;color:#374151;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:.4rem;padding:.5rem .85rem;transition:all .15s ease}.comptabilite-v2 .cpt-chip:hover{background:#f9fafb;border-color:#d1d5db}.comptabilite-v2 .cpt-chip-active{background:#111827;border-color:#111827;color:#fff}.comptabilite-v2 .cpt-chip-active .cpt-chip-count{background:#fff3;color:#fff}.comptabilite-v2 .cpt-chip-count{background:#f3f4f6;border-radius:999px;color:#6b7280;font-size:.72rem;font-weight:600;padding:.1rem .5rem}.comptabilite-v2 .cpt-chip-danger{color:#b91c1c}.comptabilite-v2 .cpt-chip-danger.cpt-chip-active{background:#dc2626;border-color:#dc2626;color:#fff}.comptabilite-v2 .cpt-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1rem}.comptabilite-v2 .cpt-search-wrap{flex:1 1;min-width:240px;position:relative}.comptabilite-v2 .cpt-search-icon{color:#9ca3af;left:.85rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.comptabilite-v2 .cpt-search-input{background:#fff;border:1px solid #e5e7eb;border-radius:10px;font-size:.9rem;padding:.65rem 2.4rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.comptabilite-v2 .cpt-search-input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.comptabilite-v2 .cpt-search-clear{align-items:center;background:#f3f4f6;border:none;border-radius:999px;color:#6b7280;cursor:pointer;display:flex;height:24px;justify-content:center;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);width:24px}.comptabilite-v2 .cpt-search-clear:hover{background:#e5e7eb}.comptabilite-v2 .cpt-filter-wrap{position:relative}.comptabilite-v2 .cpt-filter-icon{color:#9ca3af;left:.7rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.comptabilite-v2 .cpt-filter-select{font-size:.9rem;min-width:200px;padding:.65rem .85rem .65rem 2.1rem}.comptabilite-v2 .cpt-filter-select,.comptabilite-v2 .cpt-reset-btn{background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer}.comptabilite-v2 .cpt-reset-btn{align-items:center;color:#6b7280;display:inline-flex;font-size:.85rem;font-weight:500;gap:.4rem;padding:.65rem .85rem}.comptabilite-v2 .cpt-reset-btn:hover{border-color:#d1d5db;color:#111827}.comptabilite-v2 .cpt-table-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.comptabilite-v2 .cpt-table-head{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:.85rem 1.15rem}.comptabilite-v2 .cpt-table-title{color:#374151;font-size:.9rem;font-weight:600;margin:0}.comptabilite-v2 .cpt-selection-info{color:#4f46e5;font-weight:500}.comptabilite-v2 .cpt-select-all{align-items:center;color:#6b7280;cursor:pointer;display:inline-flex;font-size:.82rem;gap:.4rem}.comptabilite-v2 .cpt-table-wrap{background:#0000;border-radius:0;box-shadow:none}.comptabilite-v2 .cpt-table{border-collapse:collapse;width:100%}.comptabilite-v2 .cpt-table thead th{background:#fff;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:.72rem;font-weight:600;letter-spacing:.04em;padding:.7rem 1rem;text-align:left;text-transform:uppercase}.comptabilite-v2 .cpt-table tbody td{border-bottom:1px solid #f3f4f6;color:#1f2937;font-size:.9rem;padding:.85rem 1rem}.comptabilite-v2 .cpt-table tbody tr:last-child td{border-bottom:none}.comptabilite-v2 .cpt-table tbody tr:hover{background:#f9fafb}.comptabilite-v2 .cpt-table tbody tr.row-en-retard{background:#fef2f2}.comptabilite-v2 .cpt-table tbody tr.row-en-retard:hover{background:#fee2e2}.comptabilite-v2 .cpt-num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:500;text-align:right}.comptabilite-v2 .cpt-cell-date{display:flex;flex-direction:column;gap:.2rem}.comptabilite-v2 .cpt-retard-inline{align-items:center;color:#dc2626;display:inline-flex;font-size:.7rem;font-weight:600;gap:.25rem}.comptabilite-v2 .cpt-statut-select{background:#f3f4f6;border:1px solid #0000;border-radius:999px;color:#374151;cursor:pointer;font-size:.78rem;font-weight:600;padding:.3rem .6rem}.comptabilite-v2 .cpt-statut-non-envoyee{background:#f3f4f6;color:#4b5563}.comptabilite-v2 .cpt-statut-non-payee{background:#fee2e2;color:#b91c1c}.comptabilite-v2 .cpt-statut-en-attente{background:#fef3c7;color:#92400e}.comptabilite-v2 .cpt-statut-relancee{background:#dbeafe;color:#1e40af}.comptabilite-v2 .cpt-statut-payee{background:#d1fae5;color:#065f46}.comptabilite-v2 .cpt-statut-en-litige{background:#e5e7eb;color:#1f2937}.comptabilite-v2 .cpt-howto{align-items:flex-start;background:linear-gradient(135deg,#eff6ff,#f5f3ff);border:1px solid #c7d2fe;border-radius:12px;display:flex;gap:.85rem;margin-bottom:1.5rem;padding:1rem 1.15rem}.comptabilite-v2 .cpt-howto-icon{align-items:center;background:#4f46e5;border-radius:10px;color:#fff;display:flex;flex-shrink:0;height:34px;justify-content:center;width:34px}.comptabilite-v2 .cpt-howto-body{flex:1 1}.comptabilite-v2 .cpt-howto-body strong{color:#1e1b4b;display:block;font-size:.92rem;margin-bottom:.4rem}.comptabilite-v2 .cpt-howto-body ol{color:#4b5563;font-size:.85rem;line-height:1.6;margin:0;padding-left:1.1rem}.comptabilite-v2 .cpt-howto-body ol li{margin-bottom:.15rem}.comptabilite-v2 .cpt-howto-body ol li b{color:#1e293b;font-weight:600}.comptabilite-v2 .cpt-howto-body ol li svg{color:#6b7280;margin:0 1px;vertical-align:-2px}.comptabilite-v2 .cpt-th-with-info{align-items:center;display:inline-flex;gap:.35rem}.comptabilite-v2 .cpt-th-info{align-items:center;background:#eef2ff;border-radius:50%;color:#4f46e5;cursor:help;display:inline-flex;height:22px;justify-content:center;position:relative;transition:color .12s ease,background .12s ease,transform .12s ease;width:22px}.comptabilite-v2 .cpt-th-info:hover{background:#4f46e5;color:#fff;transform:scale(1.08)}.comptabilite-v2 .cpt-refreshing{align-items:center;animation:cptRefreshFadeIn .2s ease-out;background:#fff;border:1px solid #c7d2fe;border-radius:999px;box-shadow:0 6px 16px -6px #4f46e540;color:#4338ca;display:inline-flex;font-size:.78rem;font-weight:500;gap:.45rem;padding:.4rem .7rem;position:fixed;right:1.5rem;top:76px;z-index:30}.comptabilite-v2 .cpt-refreshing-dot{animation:cptRefreshPulse 1s ease-in-out infinite;background:#4338ca;border-radius:50%;height:8px;width:8px}@keyframes cptRefreshFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes cptRefreshPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.comptabilite-v2 .cpt-th-info[data-tooltip]:hover:after{font-weight:400;letter-spacing:normal;line-height:1.4;text-align:left;text-transform:none;white-space:normal;width:280px}.comptabilite-v2 .cpt-empty{color:#9ca3af;padding:3rem 1rem!important;text-align:center!important}.comptabilite-v2 .cpt-empty p{color:#6b7280;font-size:.95rem;font-weight:500;margin:.5rem 0 .25rem}.comptabilite-v2 .cpt-empty small{font-size:.8rem}.comptabilite-v2 .modal-header h3{align-items:center;display:inline-flex;gap:.5rem}.comptabilite-v2 .modal-close{align-items:center;border-radius:8px;display:inline-flex;height:32px;justify-content:center;width:32px}.comptabilite-v2 .cpt-info-row{border-bottom:1px solid #f3f4f6;display:flex;font-size:.88rem;justify-content:space-between;padding:.4rem 0}.comptabilite-v2 .cpt-info-row:last-child{border-bottom:none}.comptabilite-v2 .cpt-info-row span{color:#6b7280}.comptabilite-v2 .cpt-info-row strong{color:#111827;font-weight:600}@media (max-width:768px){.comptabilite-v2{padding:1rem .75rem}.comptabilite-v2 .cpt-header{align-items:stretch;flex-direction:column}.comptabilite-v2 .cpt-header-actions{width:100%}.comptabilite-v2 .cpt-header-actions .cpt-btn{flex:1 1;justify-content:center}.comptabilite-v2 .cpt-hero-cards{grid-template-columns:1fr 1fr}.comptabilite-v2 .cpt-stat-value{font-size:1.15rem}.comptabilite-v2 .cpt-toolbar{align-items:stretch;flex-direction:column}.comptabilite-v2 .cpt-filter-select,.comptabilite-v2 .cpt-reset-btn{width:100%}.comptabilite-v2 .cpt-quick-filters{flex-wrap:nowrap;overflow-x:auto;padding-bottom:.25rem}.comptabilite-v2 .cpt-chip{flex-shrink:0}}@media (max-width:480px){.comptabilite-v2 .cpt-hero-cards{grid-template-columns:1fr}}.comptabilite-v2 .cpt-chip,.comptabilite-v2 .cpt-chip-count,.comptabilite-v2 .cpt-filter-select,.comptabilite-v2 .cpt-howto,.comptabilite-v2 .cpt-howto-icon,.comptabilite-v2 .cpt-progress-block,.comptabilite-v2 .cpt-reset-btn,.comptabilite-v2 .cpt-search-input,.comptabilite-v2 .cpt-stat-card,.comptabilite-v2 .cpt-stat-icon,.comptabilite-v2 .cpt-statut-select,.comptabilite-v2 .cpt-table-card,.comptabilite-v2 .modal-close{border-radius:0!important}.comptabilite-v2 .cpt-pagination-wrap{background:#f9fafb;border-top:1px solid #e5e7eb;padding:.6rem 1rem}.comptabilite-v2 .cpt-pagination-wrap .pagination-container{margin:0}.prix-par-type{border-top:1px dashed #e5e7eb;margin-top:1rem;padding-top:.85rem}.prix-par-type-title{color:#4b5563;font-size:.85rem;font-weight:600;letter-spacing:.03em;margin:0 0 .6rem;text-transform:uppercase}.prix-par-type-title small{color:#9ca3af;font-weight:400;letter-spacing:0;text-transform:none}.search-select{position:relative;width:100%}.search-select-trigger{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:0;color:#111827;cursor:pointer;display:flex;font-size:.92rem;justify-content:space-between;padding:.55rem .7rem;text-align:left;transition:border-color .12s ease;width:100%}.search-select-trigger:hover{border-color:#9ca3af}.search-select.is-open .search-select-trigger{border-color:#000;border-color:var(--primary-color,#2563eb);box-shadow:0 0 0 3px #2563eb14}.search-select-trigger.is-disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.search-select-value{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-select-value.is-placeholder{color:#9ca3af}.search-select-chevron{color:#6b7280;flex-shrink:0;margin-left:.4rem;transition:transform .12s ease}.search-select.is-open .search-select-chevron{transform:rotate(180deg)}.search-select-dropdown{background:#fff;border:1px solid #d1d5db;box-shadow:0 12px 28px -8px #0000002e;display:flex;flex-direction:column;left:0;max-height:320px;position:absolute;right:0;top:calc(100% + 4px);z-index:100}.search-select-search{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:.5rem;position:relative}.search-select-search-icon{color:#9ca3af;left:1rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-select-search-input{background:#fff;border:1px solid #d1d5db;border-radius:0;color:#111827;font-size:.88rem;outline:none;padding:.45rem 1.8rem .45rem 2rem;width:100%}.search-select-search-input:focus{border-color:#000;border-color:var(--primary-color,#2563eb)}.search-select-search-clear{align-items:center;background:#e5e7eb;border:none;border-radius:50%;color:#4b5563;cursor:pointer;display:inline-flex;height:20px;justify-content:center;position:absolute;right:.85rem;top:50%;transform:translateY(-50%);width:20px}.search-select-list{flex:1 1;list-style:none;margin:0;overflow-y:auto;padding:.25rem 0}.search-select-option{align-items:center;color:#111827;cursor:pointer;display:flex;font-size:.9rem;gap:.6rem;justify-content:space-between;padding:.55rem .85rem}.search-select-option.is-active,.search-select-option:hover{background:#eef2ff}.search-select-option.is-selected{color:#000;color:var(--primary-color,#2563eb);font-weight:600}.search-select-option-text{display:flex;flex-direction:column;min-width:0}.search-select-option-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-select-option-sublabel{color:#6b7280;font-size:.78rem;margin-top:.1rem}.search-select-option-check{color:#000;color:var(--primary-color,#2563eb);flex-shrink:0}.search-select-empty{color:#9ca3af;font-size:.88rem;font-style:italic;padding:1rem;text-align:center}.produits-table{background:#fff;border:1px solid #e5e7eb;overflow:visible}.produits-table-head,.produits-table-row{grid-gap:.7rem;align-items:center;display:grid;gap:.7rem;grid-template-columns:32px minmax(0,3.2fr) 90px 130px 110px 40px;padding:.55rem .75rem}.produits-table-head{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.produits-table-head .col-num,.produits-table-head .col-total{text-align:center}.produits-table-row{border-bottom:1px solid #f3f4f6;transition:background .12s ease}.produits-table-row:hover{background:#fafbfc}.produits-table-row:last-of-type{border-bottom:none}.produits-table .col-num{color:#9ca3af;font-size:.85rem;font-weight:600;text-align:center}.produits-table .col-total{font-feature-settings:"tnum";color:#111827;font-size:.95rem;font-variant-numeric:tabular-nums;font-weight:700;padding-right:.25rem;text-align:right}.produits-table .col-actions{display:flex;justify-content:center}.produits-table input[type=number]{font-feature-settings:"tnum";background:#fff;border:1px solid #d1d5db;border-radius:0;color:#111827;font-size:.92rem;font-variant-numeric:tabular-nums;padding:.48rem .55rem;text-align:right;width:100%}.produits-table input[type=number]:focus{border-color:#000;border-color:var(--primary-color,#2563eb);box-shadow:0 0 0 2px #2563eb1a;outline:none}.produits-table input[type=number].is-custom{background:#fffbeb;border-color:#f59e0b}.input-with-suffix{position:relative}.input-with-suffix .suffix{font-feature-settings:normal;color:#9ca3af;font-size:.75rem;font-variant-numeric:normal;pointer-events:none;position:absolute;right:.55rem;top:50%;transform:translateY(-50%)}.input-with-suffix input[type=number]{padding-right:2.2rem}.prix-save-toggle{align-items:center;color:#b45309;cursor:pointer;display:inline-flex;font-size:.72rem;gap:.3rem;margin-top:.3rem;-webkit-user-select:none;user-select:none}.prix-save-toggle input[type=checkbox]{accent-color:#f59e0b;height:13px;margin:0;width:13px}.btn-add-ligne{background:#f9fafb;border:none;border-top:1px dashed #e5e7eb;color:#000;color:var(--primary-color,#2563eb);cursor:pointer;font-size:.86rem;font-weight:500;padding:.65rem;transition:background .12s ease;width:100%}.btn-add-ligne:hover{background:#eef2ff}.produits-table .btn-action.btn-danger{align-items:center;background:#0000;border:1px solid #0000;color:#ef4444;display:inline-flex;height:28px;justify-content:center;padding:0;transition:background .12s,color .12s;width:28px}.produits-table .btn-action.btn-danger:hover{background:#fee2e2;border-color:#fecaca}@media (max-width:820px){.produits-table-head{display:none}.produits-table-row{grid-template-areas:"num actions" "produit produit" "qte prix" "total total";grid-template-columns:1fr 40px;row-gap:.5rem}.produits-table .col-num{grid-area:num;text-align:left}.produits-table .col-actions{grid-area:actions}.produits-table .col-produit{grid-area:produit}.produits-table .col-qte{grid-area:qte}.produits-table .col-prix{grid-area:prix}.produits-table .col-total{border-top:1px dashed #f3f4f6;grid-area:total;padding-top:.3rem;text-align:right}}.statistiques .stats-kpi-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:1.5rem}.statistiques .stats-kpi-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:0;display:flex;gap:.85rem;padding:1.1rem 1.15rem;transition:transform .15s ease,box-shadow .15s ease}.statistiques .stats-kpi-card:hover{box-shadow:0 8px 20px -8px #0000001f;transform:translateY(-2px)}.statistiques .stats-kpi-icon{align-items:center;border-radius:0;display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.statistiques .stats-kpi-icon-blue{background:#eff6ff;color:#2563eb}.statistiques .stats-kpi-icon-green{background:#ecfdf5;color:#059669}.statistiques .stats-kpi-label{color:#6b7280;display:block;font-size:.8rem;font-weight:500}.statistiques .stats-kpi-value{color:#111827;display:block;font-size:1.4rem;font-weight:700}.statistiques .stats-tabs{background:#f3f4f6;border-radius:0;display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem;padding:.4rem}.statistiques .stats-tab{align-items:center;background:#0000;border:none;border-radius:0;color:#6b7280;cursor:pointer;display:flex;flex:1 1;font-size:.875rem;font-weight:500;gap:.4rem;min-width:120px;padding:.55rem .85rem;position:relative;transition:background .15s ease,color .15s ease}.statistiques .stats-tab small{display:none}.statistiques .stats-tab:hover{background:#fff;color:#111827}.statistiques .stats-tab-active{background:#fff;box-shadow:0 1px 2px #0000000d;color:#111827}.statistiques .stats-search-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem}.statistiques .stats-search-input-wrap{min-width:240px;position:relative}.statistiques .stats-search-icon{color:#9ca3af;left:.7rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.statistiques .stats-search-input{background:#fff;border:1px solid #e5e7eb;border-radius:0;font-size:.875rem;padding:.55rem 2.2rem;transition:border-color .15s ease,box-shadow .15s ease;width:100%}.statistiques .stats-search-input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a;outline:none}.statistiques .stats-search-clear{align-items:center;background:#f3f4f6;border:none;border-radius:999px;color:#6b7280;cursor:pointer;display:flex;height:22px;justify-content:center;position:absolute;right:.4rem;top:50%;transform:translateY(-50%);width:22px}.statistiques .stats-search-clear:hover{background:#e5e7eb}.statistiques .stats-tab-active small{color:#6b7280;display:none}.cmd-th-with-info{gap:.35rem}.cmd-th-info,.cmd-th-with-info{align-items:center;display:inline-flex}.cmd-th-info{background:#eef2ff;border-radius:50%;color:#4f46e5;cursor:help;height:22px;justify-content:center;position:relative;transition:color .12s ease,background .12s ease,transform .12s ease;width:22px}.cmd-th-info:hover{background:#4f46e5;color:#fff;transform:scale(1.08)}.cmd-th-info[data-tooltip]:hover:after{font-weight:400;letter-spacing:normal;line-height:1.4;text-align:left;text-transform:none;white-space:normal;width:280px}.statistiques .stats-tab-panel{background:#fff;border:1px solid #e5e7eb;border-radius:0;padding:1.25rem}.statistiques .stats-chart-card{margin-bottom:1rem}.statistiques .stats-chart-card h3{color:#374151;font-size:1rem;font-weight:600;margin:0 0 .75rem}.statistiques .stats-clickable-table tbody tr{cursor:pointer;transition:background .12s ease}.statistiques .stats-clickable-table tbody tr:hover{background:#f9fafb}.statistiques .stats-clickable-table tbody tr:hover td:last-child{color:#4f46e5!important}.statistiques .stats-year-selector{align-items:center;display:flex;font-size:.875rem;gap:.5rem;margin-bottom:.75rem}.statistiques .stats-year-selector select{background:#fff;border:1px solid #e5e7eb;border-radius:0;cursor:pointer;padding:.4rem .7rem}.statistiques .stats-kpi-row{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr)}.statistiques .stats-kpi-mini{background:#f9fafb;border:1px solid #e5e7eb;border-radius:0;display:flex;flex-direction:column;padding:.7rem .85rem}.statistiques .stats-kpi-mini .stats-kpi-value{font-size:1.1rem}@media (max-width:768px){.statistiques .stats-tab{flex-basis:calc(50% - 0.4rem);flex-grow:1;flex-shrink:1;min-width:0}.statistiques .stats-tab small{display:none!important}.statistiques .stats-kpi-row{grid-template-columns:1fr}}.action-menu-wrapper{display:inline-block;position:relative}.action-menu-trigger{align-items:center;background:#0000;border:1px solid #0000;border-radius:8px;color:#6b7280;cursor:pointer;display:inline-flex;height:32px;justify-content:center;transition:background .12s ease,color .12s ease,border-color .12s ease;width:32px}.action-menu-trigger:hover{background:#f3f4f6;border-color:#e5e7eb;color:#111827}.action-menu-trigger[aria-expanded=true]{background:#e5e7eb;color:#111827}.action-menu{animation:actionMenuFadeIn .12s ease-out;background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 10px 28px -8px #0000002e,0 4px 10px -4px #00000014;min-width:220px;padding:.35rem;position:fixed;z-index:1000}@keyframes actionMenuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.action-menu-item{align-items:center;background:#0000;border:none;border-radius:6px;color:#1f2937;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:.55rem;padding:.5rem .7rem;text-align:left;transition:background .1s ease,color .1s ease;width:100%}.action-menu-item:hover:not(:disabled){background:#f3f4f6}.action-menu-item:disabled{cursor:not-allowed;opacity:.4}.action-menu-item-warning{color:#b45309}.action-menu-item-warning:hover:not(:disabled){background:#fffbeb}.action-menu-item-success{color:#059669}.action-menu-item-success:hover:not(:disabled){background:#ecfdf5}.action-menu-item-danger{color:#b91c1c}.action-menu-item-danger:hover:not(:disabled){background:#fef2f2}.action-menu-separator{background:#f3f4f6;height:1px;margin:.3rem 0}.users-table .role-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.72rem;font-weight:600;letter-spacing:.02em;padding:.25rem .6rem}.users-table .role-badge.role-admin{background:#fee2e2;color:#b91c1c}.users-table .role-badge.role-comptable{background:#dbeafe;color:#1e40af}.users-table .role-badge.role-user{background:#f3f4f6;color:#4b5563}.users-table .user-status-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.72rem;font-weight:600;padding:.25rem .6rem}.users-table .user-status-badge.active{background:#d1fae5;color:#065f46}.users-table .user-status-badge.inactive{background:#f3f4f6;color:#6b7280}.stock-alerts-v2{background:#fff;border:1px solid #fde68a;border-radius:12px;margin-bottom:1.25rem;overflow:hidden}.stock-alerts-header{align-items:center;background:linear-gradient(90deg,#fffbeb,#fef3c7);border-bottom:1px solid #fde68a;display:flex;justify-content:space-between;padding:.85rem 1.1rem}.stock-alerts-title{align-items:center;color:#92400e;display:flex;gap:.5rem}.stock-alerts-title h3{font-size:.95rem;font-weight:600;margin:0}.stock-alerts-count{background:#92400e;border-radius:999px;color:#fff;font-size:.7rem;font-weight:700;padding:.1rem .5rem}.stock-alerts-toggle{align-items:center;background:#0000;border:1px solid #d97706;border-radius:999px;color:#92400e;cursor:pointer;display:inline-flex;font-size:.78rem;font-weight:500;gap:.3rem;padding:.3rem .7rem;transition:background .15s ease,color .15s ease}.stock-alerts-toggle:hover{background:#92400e;color:#fff}.stock-alerts-list{max-height:280px;overflow-y:auto;padding:.5rem}.stock-alert-item{align-items:center;border-radius:8px;display:flex;gap:.75rem;padding:.65rem .85rem;transition:background .12s ease}.stock-alert-item+.stock-alert-item{border-top:1px solid #fef3c7}.stock-alert-item:hover{background:#fffbeb}.stock-alert-icon{align-items:center;border-radius:8px;display:inline-flex;flex-shrink:0;height:28px;justify-content:center;width:28px}.stock-alert-critique .stock-alert-icon{background:#fee2e2;color:#b91c1c}.stock-alert-faible .stock-alert-icon{background:#fef3c7;color:#b45309}.stock-alert-body{display:flex;flex:1 1;flex-direction:column;min-width:0}.stock-alert-body strong{color:#1f2937;font-size:.875rem;font-weight:600}.stock-alert-stock{color:#6b7280;font-size:.78rem;margin-top:.1rem}.stock-alert-seuil{color:#9ca3af;margin-left:.4rem}.stock-alert-badge{border-radius:999px;font-size:.7rem;font-weight:600;padding:.2rem .55rem;white-space:nowrap}.stock-alert-badge-critique{background:#fee2e2;color:#b91c1c}.stock-alert-badge-faible{background:#fef3c7;color:#b45309}@media (max-width:768px){.stock-alerts-header{align-items:flex-start;flex-direction:column;gap:.5rem}.stock-alerts-toggle{align-self:flex-end}}.header-buttons .btn svg{flex-shrink:0}:root{--onboarding-primary-color:#8cc63f;--onboarding-primary-dark:#6ba82d}.onboarding-overlay{align-items:center;animation:fadeIn .3s ease-out;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.onboarding-overlay.exiting{animation:fadeOut .3s ease-out}.onboarding-backdrop{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0009;bottom:0;left:0;position:absolute;right:0;top:0}.onboarding-modal{animation:slideUp .4s cubic-bezier(.34,1.56,.64,1);background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:85vh;max-width:700px;overflow:hidden;position:relative;width:90%}.onboarding-modal.complete{max-width:650px}.onboarding-header{background:linear-gradient(135deg,#8cc63f,#6ba82d);background:linear-gradient(135deg,var(--onboarding-primary-color) 0,var(--onboarding-primary-dark) 100%);color:#fff;padding:0}.onboarding-progress-bar{background:#fff3;height:4px;overflow:hidden}.onboarding-progress-fill{background:#fff;box-shadow:0 0 10px #ffffff80;height:100%;transition:width .4s ease-out}.onboarding-step-info{align-items:center;display:flex;justify-content:space-between;padding:1rem 1.5rem}.step-counter{font-size:.875rem;font-weight:600;opacity:.95}.onboarding-skip-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.onboarding-skip-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.onboarding-body{animation:contentFade .3s ease-out;flex:1 1;overflow-y:auto;padding:2rem 2.5rem}.onboarding-title-section{margin-bottom:1.5rem}.onboarding-title{color:#2c3e50;font-size:1.75rem;font-weight:700;line-height:1.3;margin:0 0 .5rem}.onboarding-subtitle{color:#7f8c8d;font-size:1rem;font-weight:400;margin:0}.onboarding-content-section{animation:contentSlide .4s ease-out}.onboarding-content{color:#34495e;font-size:1rem;line-height:1.7}.onboarding-content p{margin:0 0 1rem}.onboarding-content ul{list-style:none;margin:1rem 0;padding:0}.onboarding-content li{line-height:1.6;padding:.6rem 0 .6rem 1.5rem;position:relative}.onboarding-content li:before{background:#8cc63f;background:var(--onboarding-primary-color);border-radius:50%;content:"";height:6px;left:0;position:absolute;top:.9rem;width:6px}.tip{background:linear-gradient(135deg,#fff3cd,#fff9e6);border-left:4px solid #ffc107;border-radius:8px;font-size:.95rem;margin-top:1.5rem;padding:1rem 1.25rem}.tip strong{color:#e67e22}.onboarding-welcome{text-align:center}.welcome-icon{animation:bounce 1s infinite;font-size:4rem;margin-bottom:1rem}.onboarding-welcome h2{color:#2c3e50;font-size:1.5rem;margin:0 0 1rem}.onboarding-welcome p{color:#555;font-size:1rem;line-height:1.7;margin-bottom:1.5rem}.welcome-features{display:flex;flex-direction:column;gap:1rem;margin:2rem 0;text-align:left}.feature-item{align-items:center;background:#f8f9fa;border-radius:10px;display:flex;gap:1rem;padding:1rem;transition:all .3s}.feature-item:hover{background:#e9ecef;transform:translateX(5px)}.feature-icon{flex-shrink:0;font-size:1.5rem}.welcome-note{background:linear-gradient(135deg,#d4edda,#e8f5e9);border-left:4px solid #28a745;border-radius:8px;margin-top:1.5rem;padding:1rem 1.25rem;text-align:left}.onboarding-complete{text-align:center}.complete-icon{animation:scaleUp .6s cubic-bezier(.34,1.56,.64,1);font-size:5rem;margin-bottom:1rem}.onboarding-complete h2{color:#2c3e50;font-size:1.75rem;font-weight:700;margin:0 0 1rem}.onboarding-complete p{color:#555;font-size:1rem;line-height:1.7}.complete-actions{background:#f8f9fa;border-radius:12px;margin:1.5rem 0;padding:1.5rem;text-align:left}.complete-actions p{color:#2c3e50;font-weight:600;margin:0 0 1rem}.complete-actions ol{margin:0;padding-left:1.5rem}.complete-actions li{line-height:1.6;margin:.5rem 0}.complete-note{background:linear-gradient(135deg,#cfe2ff,#e7f1ff);border-left:4px solid #0d6efd;border-radius:8px;margin-top:1.5rem;padding:1rem 1.25rem;text-align:left}.support-image-container{margin:1rem 0 1.5rem;text-align:center}.support-image{border-radius:12px;box-shadow:0 4px 12px #00000026;height:auto;max-width:200px;transition:transform .3s,box-shadow .3s;width:100%}.support-image:hover{box-shadow:0 6px 16px #0003;transform:scale(1.05)}.support-contact{background:#f8f9fa;border-radius:12px;margin:1.5rem 0;padding:1.5rem;text-align:center}.support-contact p{color:#2c3e50;font-weight:600;margin:0 0 1rem}.support-link{background:linear-gradient(135deg,#8cc63f,#6ba82d);background:linear-gradient(135deg,var(--onboarding-primary-color) 0,var(--onboarding-primary-dark) 100%);border-radius:10px;box-shadow:0 4px 15px #8cc63f4d;color:#fff;display:inline-block;font-weight:600;padding:.875rem 1.5rem;text-decoration:none;transition:all .3s}.support-link:hover{box-shadow:0 6px 20px #8cc63f66;color:#fff;text-decoration:none;transform:translateY(-2px)}.onboarding-footer{align-items:center;background:#f8f9fa;border-top:1px solid #e9ecef;display:flex;justify-content:space-between;padding:1.5rem 2.5rem}.onboarding-btn{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:.75rem 1.5rem;transition:all .3s}.onboarding-btn.btn-primary{background:linear-gradient(135deg,#8cc63f,#6ba82d);background:linear-gradient(135deg,var(--onboarding-primary-color) 0,var(--onboarding-primary-dark) 100%);box-shadow:0 4px 15px #8cc63f4d;color:#fff}.onboarding-btn.btn-primary:hover{box-shadow:0 6px 20px #8cc63f66;transform:translateY(-2px)}.onboarding-btn.btn-secondary{background:#fff;border:2px solid #dee2e6;color:#6c757d}.onboarding-btn.btn-secondary:hover:not(:disabled){background:#f8f9fa;border-color:#8cc63f;border-color:var(--onboarding-primary-color);color:#8cc63f;color:var(--onboarding-primary-color)}.onboarding-btn:disabled{cursor:not-allowed;opacity:.4}.onboarding-btn.btn-outline{background:#fff;border:2px solid #8cc63f;border:2px solid var(--onboarding-primary-color);color:#8cc63f;color:var(--onboarding-primary-color)}.onboarding-btn.btn-outline:hover{background:#8cc63f;background:var(--onboarding-primary-color);color:#fff;transform:translateY(-2px)}.onboarding-final-actions{align-items:center;display:flex;gap:1rem}.onboarding-dots{align-items:center;display:flex;gap:.5rem}.dot{background:#dee2e6;border-radius:50%;cursor:pointer;height:10px;transition:all .3s;width:10px}.dot.active{box-shadow:0 0 10px #8cc63f80;height:12px;width:12px}.dot.active,.dot.completed{background:#8cc63f;background:var(--onboarding-primary-color)}.dot.completed{opacity:.5}.dot:hover{transform:scale(1.2)}.confetti{animation:confettiFall linear forwards;background:#8cc63f;background:var(--onboarding-primary-color);height:10px;position:absolute;width:10px;z-index:10001}@keyframes confettiFall{0%{opacity:1;top:-10%;transform:translateX(0) rotate(0deg)}to{opacity:0;top:110%;transform:translateX(100px) rotate(2turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(50px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes contentFade{0%{opacity:0}to{opacity:1}}@keyframes contentSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes scaleUp{0%{transform:scale(0)}to{transform:scale(1)}}@media (max-width:768px){.onboarding-modal{border-radius:15px;max-height:90vh;width:95%}.onboarding-body{padding:1.5rem}.onboarding-footer{flex-wrap:wrap;gap:1rem;padding:1rem 1.5rem}.onboarding-dots{justify-content:center;order:-1;width:100%}.onboarding-btn{flex:1 1;min-width:auto}.onboarding-title{font-size:1.4rem}.complete-icon,.welcome-icon{font-size:3rem}.feature-item{padding:.75rem}.support-image{border-radius:8px;max-width:100%}.onboarding-final-actions{flex-direction:column;width:100%}.onboarding-final-actions .onboarding-btn{width:100%}}
/*# sourceMappingURL=main.f6657cdf.css.map*/