*,: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.17 | 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}.table{display:table}.hidden{display:none}.border{border-width:1px}.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)}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 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{border:none;display:inline-flex;font-size:.75rem;transition:all .2s ease}.btn-action.btn-primary{background:#0d6efd;color:#fff}.btn-action.btn-primary:hover{background:#0b5ed7;transform:translateY(-1px)}.btn-action.btn-success{background:#198754;color:#fff}.btn-action.btn-success:hover{background:#157347;transform:translateY(-1px)}.btn-action.btn-warning{background:#ffc107;color:#000}.btn-action.btn-warning:hover{background:#e0a800;transform:translateY(-1px)}.btn-action.btn-danger{background:#dc3545;color:#fff}.btn-action.btn-danger:hover{background:#bb2d3b;transform:translateY(-1px)}.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}@media (max-width:992px){.header-actions{align-items:flex-end;flex-direction:column;gap:.25rem}.header-user-info{font-size:.8rem}.header-btn{font-size:.75rem;padding:.3rem .6rem}}@media (max-width:576px){.header-actions{gap:.2rem}.header-user-info{font-size:.75rem}.header-btn{font-size:.7rem;padding:.25rem .5rem}}.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:all .3s ease}.btn.btn-primary:hover{box-shadow:0 4px 12px #8cc63f66;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}.btn.btn-secondary:hover{box-shadow:0 4px 12px #6c757d66;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;border-radius:0;border-radius:var(--border-radius);box-shadow:0 4px 20px #0000001a;box-shadow:var(--shadow);margin-bottom:2rem;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)}.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:stretch;display:flex;flex-direction:column;gap:.25rem}.commandes .action-buttons .btn-action{font-size:.8rem;padding:.25rem .5rem;white-space:nowrap}.users .action-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.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}.btn-action.btn-edit{background-color:#6c757d;border-color:#6c757d;color:#fff}.btn-action.btn-edit:hover{background-color:#5a6268;border-color:#545b62;transform:translateY(-1px)}.btn-action.btn-delete{background-color:#dc3545;border-color:#dc3545;color:#fff}.btn-action.btn-delete:hover{background-color:#c82333;border-color:#bd2130;transform:translateY(-1px)}.btn-action.btn-view{background-color:#17a2b8;border-color:#17a2b8;color:#fff}.btn-action.btn-view:hover{background-color:#138496;border-color:#117a8b;transform:translateY(-1px)}.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:column;gap:.125rem}.btn-action{font-size:.75rem;padding:.25rem .5rem}}.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{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:center}.header-logo{align-items:center;display:flex;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{align-items:center;animation:slideIn .3s ease-out;border-radius:0;box-shadow:0 8px 30px #00000026;box-shadow:var(--shadow-hover);display:flex;gap:.75rem;min-width:300px;padding:1rem}.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-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1.2rem;opacity:.8;transition:opacity .2s}.notification-close:hover{opacity: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,.header-logo{flex-direction:column}.header-logo{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{font-size:.75rem;height:28px;min-width:30px;padding:.25rem .375rem}}.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}}
/*# sourceMappingURL=main.e1b5ead1.css.map*/