@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-primary: #4F46E5;--color-primary-hover: #4338CA;--color-primary-active: #3730A3;--color-primary-light: #818CF8;--color-primary-subtle: #EEF2FF;--color-primary-foreground: #FFFFFF;--color-neutral-50: #FAFAF9;--color-neutral-100: #F5F5F4;--color-neutral-200: #E7E5E4;--color-neutral-300: #D6D3D1;--color-neutral-400: #A8A29E;--color-neutral-500: #78716C;--color-neutral-600: #57534E;--color-neutral-700: #44403C;--color-neutral-800: #292524;--color-neutral-900: #1C1917;--color-neutral-950: #0C0A09;--color-success: #059669;--color-success-light: #10B981;--color-success-subtle: #ECFDF5;--color-success-foreground: #FFFFFF;--color-warning: #D97706;--color-warning-light: #F59E0B;--color-warning-subtle: #FFFBEB;--color-warning-foreground: #FFFFFF;--color-error: #DC2626;--color-error-light: #EF4444;--color-error-subtle: #FEF2F2;--color-error-foreground: #FFFFFF;--color-info: #2563EB;--color-info-light: #3B82F6;--color-info-subtle: #EFF6FF;--color-info-foreground: #FFFFFF;--background: #FFFFFF;--background-secondary: #FAFAF9;--background-tertiary: #F5F5F4;--background-elevated: #FFFFFF;--background-sunken: #F5F5F4;--background-overlay: rgba(0, 0, 0, .4);--background-backdrop: rgba(0, 0, 0, .6);--foreground: #1C1917;--foreground-secondary: #57534E;--foreground-muted: #A8A29E;--foreground-subtle: #D6D3D1;--foreground-inverse: #FFFFFF;--border: #E7E5E4;--border-secondary: #D6D3D1;--border-subtle: #F5F5F4;--border-hover: #D6D3D1;--border-focus: var(--color-primary);--border-error: var(--color-error);--interactive-hover: #F5F5F4;--interactive-active: #E7E5E4;--interactive-selected: var(--color-primary-subtle);--card: #FFFFFF;--card-hover: #FAFAF9;--card-border: #E7E5E4;--input-background: #FFFFFF;--input-border: #E7E5E4;--input-border-hover: #D6D3D1;--input-border-focus: var(--color-primary);--input-placeholder: #78716C;--sidebar-background: #FAFAF9;--sidebar-foreground: #1C1917;--sidebar-border: #E7E5E4;--sidebar-item-hover: #F5F5F4;--sidebar-item-active: var(--color-primary-subtle);--sidebar-item-active-text: var(--color-primary);--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .03);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .04), 0 1px 2px -1px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .06), 0 4px 6px -4px rgba(0, 0, 0, .06);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08), 0 8px 10px -6px rgba(0, 0, 0, .08);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--ring-color: rgba(79, 70, 229, .2);--ring-offset: 2px;--ring-width: 3px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-display: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, monospace;--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .875rem;--text-lg: 1rem;--text-xl: 1.125rem;--text-2xl: 1.25rem;--text-3xl: 1.5rem;--text-4xl: 1.875rem;--text-5xl: 2.25rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--tracking-tighter: -.05em;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--space-0: 0;--space-px: 1px;--space-0-5: .125rem;--space-1: .25rem;--space-1-5: .375rem;--space-2: .5rem;--space-2-5: .625rem;--space-3: .75rem;--space-3-5: .875rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 1.75rem;--space-8: 2rem;--space-9: 2.25rem;--space-10: 2.5rem;--space-12: 3rem;--space-14: 3.5rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-none: 0;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-3xl: 1.5rem;--radius-full: 9999px;--duration-fast: .1s;--duration-normal: .15s;--duration-slow: .2s;--duration-slower: .3s;--duration-slowest: .5s;--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--transition-fast: var(--duration-fast) var(--ease-default);--transition-normal: var(--duration-normal) var(--ease-default);--transition-base: var(--duration-normal) var(--ease-default);--transition-slow: var(--duration-slow) var(--ease-default);--sidebar-width: 260px;--sidebar-width-collapsed: 72px;--header-height: 56px;--container-max: 1440px;--container-padding: var(--space-6);--z-hide: -1;--z-base: 0;--z-docked: 10;--z-sidebar: 40;--z-dropdown: 1000;--z-sticky: 1100;--z-banner: 1200;--z-overlay: 1300;--z-modal: 1400;--z-popover: 1500;--z-skipLink: 1600;--z-toast: 1700;--z-tooltip: 1800;--color-primary-500: var(--color-primary);--color-primary-600: var(--color-primary-hover);--color-primary-700: var(--color-primary-active);--bg-primary: var(--background);--bg-secondary: var(--background-secondary);--bg-card: var(--card);--bg-surface: var(--background);--bg-surface-hover: var(--interactive-hover);--text-primary: var(--foreground);--text-secondary: var(--foreground-secondary);--text-muted: var(--foreground-muted);--border-color: var(--border);--border-color-hover: var(--border-secondary);--spacing-xs: var(--space-1);--spacing-sm: var(--space-2);--spacing-md: var(--space-4);--spacing-lg: var(--space-6);--spacing-xl: var(--space-8);--spacing-2xl: var(--space-12)}.dark,[data-theme=dark]{--background: #09090B;--background-secondary: #18181B;--background-tertiary: #27272A;--background-elevated: #18181B;--background-sunken: #09090B;--background-overlay: rgba(0, 0, 0, .7);--background-backdrop: rgba(0, 0, 0, .8);--foreground: #FAFAFA;--foreground-secondary: #A1A1AA;--foreground-muted: #71717A;--foreground-subtle: #52525B;--foreground-inverse: #09090B;--border: #27272A;--border-secondary: #3F3F46;--border-subtle: #18181B;--border-hover: #3F3F46;--interactive-hover: #27272A;--interactive-active: #3F3F46;--interactive-selected: rgba(79, 70, 229, .15);--card: #18181B;--card-hover: #27272A;--card-border: #27272A;--input-background: #18181B;--input-border: #27272A;--input-border-hover: #3F3F46;--input-placeholder: #A1A1AA;--sidebar-background: #18181B;--sidebar-foreground: #FAFAFA;--sidebar-border: #27272A;--sidebar-item-hover: #27272A;--sidebar-item-active: rgba(79, 70, 229, .15);--sidebar-item-active-text: #818CF8;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .4), 0 1px 2px -1px rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5), 0 2px 4px -2px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .6), 0 4px 6px -4px rgba(0, 0, 0, .6);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .7), 0 8px 10px -6px rgba(0, 0, 0, .7);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .8);--ring-color: rgba(129, 140, 248, .3);--color-primary-subtle: rgba(79, 70, 229, .15);--color-success-subtle: rgba(5, 150, 105, .15);--color-warning-subtle: rgba(217, 119, 6, .15);--color-error-subtle: rgba(220, 38, 38, .15);--color-info-subtle: rgba(37, 99, 235, .15);--bg-primary: var(--background);--bg-secondary: var(--background-secondary);--bg-card: var(--card);--bg-surface: var(--background);--bg-surface-hover: var(--interactive-hover);--text-primary: var(--foreground);--text-secondary: var(--foreground-secondary);--text-muted: var(--foreground-muted);--border-color: var(--border);--border-color-hover: var(--border-secondary)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-normal);color:var(--foreground);background-color:var(--background);min-height:100vh}:focus-visible{outline:none;box-shadow:0 0 0 var(--ring-offset) var(--background),0 0 0 calc(var(--ring-offset) + var(--ring-width)) var(--ring-color)}:focus:not(:focus-visible){outline:none}::selection{background-color:var(--color-primary-subtle);color:var(--color-primary)}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--foreground);letter-spacing:var(--tracking-tight)}h1{font-size:var(--text-4xl);font-weight:var(--font-bold);letter-spacing:var(--tracking-tighter)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base);font-weight:var(--font-medium)}p{color:var(--foreground-secondary);line-height:var(--leading-relaxed)}small{font-size:var(--text-sm);color:var(--foreground-muted)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}code,kbd,pre,samp{font-family:var(--font-mono);font-size:.9em}code{padding:var(--space-0-5) var(--space-1);background-color:var(--background-tertiary);border-radius:var(--radius-sm);color:var(--foreground)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full);border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background:var(--foreground-muted);border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-corner{background:transparent}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.app-layout{display:flex;min-height:100vh;background-color:var(--background)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;background-color:var(--background);transition:margin-left var(--transition-slow)}.sidebar-collapsed .main-content{margin-left:var(--sidebar-width-collapsed)}.page-container{max-width:var(--container-max);margin:0 auto;padding:var(--container-padding)}.page-header{margin-bottom:var(--space-6)}.page-title{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--foreground);margin-bottom:var(--space-1)}.page-subtitle{font-size:var(--text-base);color:var(--foreground-muted)}.grid{display:grid;gap:var(--space-4)}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.col-span-1{grid-column:span 1 / span 1}.col-span-2{grid-column:span 2 / span 2}.col-span-3{grid-column:span 3 / span 3}.col-span-4{grid-column:span 4 / span 4}.col-span-full{grid-column:1 / -1}@media(max-width:1280px){.grid-cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-5,.grid-cols-6{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:1024px){.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.main-content{margin-left:0}.grid-cols-2,.grid-cols-3,.grid-cols-4,.grid-cols-5,.grid-cols-6{grid-template-columns:repeat(1,minmax(0,1fr))}.col-span-2,.col-span-3,.col-span-4{grid-column:span 1 / span 1}.page-container{padding:var(--space-4)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--duration-slow) var(--ease-out)}.animate-slide-up{animation:slideInUp var(--duration-slow) var(--ease-out)}.animate-slide-down{animation:slideInDown var(--duration-slow) var(--ease-out)}.animate-scale-in{animation:scaleIn var(--duration-slow) var(--ease-out)}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s var(--ease-in-out) infinite}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.flex-1{flex:1 1 0%}.flex-auto{flex:1 1 auto}.flex-none{flex:none}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.items-baseline{align-items:baseline}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-evenly{justify-content:space-evenly}.gap-0{gap:0}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.gap-10{gap:var(--space-10)}.gap-12{gap:var(--space-12)}.w-full{width:100%}.w-auto{width:auto}.w-screen{width:100vw}.h-full{height:100%}.h-auto{height:auto}.h-screen{height:100vh}.min-h-screen{min-height:100vh}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-scroll{overflow:scroll}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{inset:0}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.whitespace-pre-wrap{white-space:pre-wrap}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.cursor-wait{cursor:wait}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.select-none{-webkit-user-select:none;user-select:none}.select-text{-webkit-user-select:text;user-select:text}.select-all{-webkit-user-select:all;user-select:all}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.rounded-none{border-radius:0}.rounded-sm{border-radius:var(--radius-sm)}.rounded,.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-none{box-shadow:none}.shadow-xs{box-shadow:var(--shadow-xs)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow,.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.shadow-2xl{box-shadow:var(--shadow-2xl)}.transition-none{transition:none}.transition-all{transition:all var(--transition-normal)}.transition-colors{transition:color,background-color,border-color,fill,stroke var(--transition-normal)}.transition-opacity{transition:opacity var(--transition-normal)}.transition-transform{transition:transform var(--transition-normal)}@media print{.print\\:hidden{display:none!important}body{background:#fff;color:#000}.main-content{margin-left:0}.no-print{display:none!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:var(--leading-none);text-decoration:none;white-space:nowrap;border:1px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.btn:disabled,.btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn:focus-visible{outline:none;box-shadow:0 0 0 var(--ring-offset) var(--background),0 0 0 calc(var(--ring-offset) + var(--ring-width)) var(--ring-color)}.btn-xs{padding:var(--space-1) var(--space-2);font-size:var(--text-xs);border-radius:var(--radius-md)}.btn-sm{padding:var(--space-1-5) var(--space-3);font-size:var(--text-sm)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base)}.btn-xl{padding:var(--space-4) var(--space-8);font-size:var(--text-lg)}.btn-primary{background-color:var(--color-primary);color:var(--color-primary-foreground);border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-active);border-color:var(--color-primary-active)}.btn-secondary{background-color:var(--background);color:var(--foreground);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background-color:var(--interactive-hover);border-color:var(--border-secondary)}.btn-secondary:active:not(:disabled){background-color:var(--interactive-active)}.btn-outline{background-color:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn-outline:hover:not(:disabled){background-color:var(--color-primary-subtle)}.btn-ghost{background-color:transparent;color:var(--foreground-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background-color:var(--interactive-hover);color:var(--foreground)}.btn-destructive{background-color:var(--color-error);color:var(--color-error-foreground);border-color:var(--color-error)}.btn-destructive:hover:not(:disabled){background-color:var(--color-error-light);border-color:var(--color-error-light)}.btn-success{background-color:var(--color-success);color:var(--color-success-foreground);border-color:var(--color-success)}.btn-success:hover:not(:disabled){background-color:var(--color-success-light);border-color:var(--color-success-light)}.btn-icon{padding:var(--space-2);width:36px;height:36px}.btn-icon.btn-xs{padding:var(--space-1);width:24px;height:24px}.btn-icon.btn-sm{padding:var(--space-1-5);width:32px;height:32px}.btn-icon.btn-lg{padding:var(--space-3);width:44px;height:44px}.form-group{display:flex;flex-direction:column;gap:var(--space-1-5)}.form-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--foreground)}.form-label-required:after{content:" *";color:var(--color-error)}.form-hint{font-size:var(--text-xs);color:var(--foreground-muted)}.form-error{font-size:var(--text-xs);color:var(--color-error)}.input{width:100%;padding:var(--space-2) var(--space-3);font-family:var(--font-sans);font-size:var(--text-sm);line-height:var(--leading-normal);color:var(--foreground);background-color:var(--input-background);border:1px solid var(--input-border);border-radius:var(--radius-lg);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input::placeholder{color:var(--input-placeholder)}.input:hover:not(:disabled):not(:focus){border-color:var(--input-border-hover)}.input:focus{border-color:var(--input-border-focus);box-shadow:0 0 0 var(--ring-width) var(--ring-color)}.input:disabled{background-color:var(--background-tertiary);color:var(--foreground-muted);cursor:not-allowed}.input-error{border-color:var(--color-error)}.input-error:focus{box-shadow:0 0 0 var(--ring-width) #dc262633}.input-sm{padding:var(--space-1-5) var(--space-2-5);font-size:var(--text-xs)}.input-lg{padding:var(--space-3) var(--space-4);font-size:var(--text-base)}.textarea{min-height:80px;resize:vertical}.select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23a8a29e' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right var(--space-2) center;background-repeat:no-repeat;background-size:20px;padding-right:var(--space-10)}.checkbox,.radio{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.checkbox-label,.radio-label{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--foreground);cursor:pointer}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper .input{padding-left:var(--space-10)}.input-wrapper .input-icon{position:absolute;left:var(--space-3);color:var(--foreground-muted);pointer-events:none}.input-wrapper .input-icon-right{left:auto;right:var(--space-3)}.input-wrapper .input-icon-right+.input{padding-left:var(--space-3);padding-right:var(--space-10)}.input-group{display:flex}.input-group .input{border-radius:0}.input-group .input:first-child{border-top-left-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-lg)}.input-group .input:last-child{border-top-right-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.input-group-addon{display:flex;align-items:center;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--foreground-muted);background-color:var(--background-tertiary);border:1px solid var(--input-border)}.input-group-addon:first-child{border-right:0;border-top-left-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-lg)}.input-group-addon:last-child{border-left:0;border-top-right-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.card{background-color:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);overflow:hidden}.card-hover{transition:border-color var(--transition-normal),box-shadow var(--transition-normal)}.card-hover:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-md)}.card-clickable{cursor:pointer}.card-clickable:hover{border-color:var(--color-primary)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border)}.card-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--foreground)}.card-description{font-size:var(--text-sm);color:var(--foreground-muted);margin-top:var(--space-0-5)}.card-body{padding:var(--space-5)}.card-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border);background-color:var(--background-secondary)}.card-compact .card-header,.card-compact .card-body,.card-compact .card-footer{padding:var(--space-3) var(--space-4)}.card-flat{border:none;box-shadow:none}.stat-card{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5);background-color:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);transition:border-color var(--transition-normal),box-shadow var(--transition-normal)}.stat-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-sm)}.stat-card-header{display:flex;align-items:center;justify-content:space-between}.stat-card-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-lg);background-color:var(--color-primary-subtle);color:var(--color-primary)}.stat-card-trend{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-weight:var(--font-medium)}.stat-card-trend.up{color:var(--color-success)}.stat-card-trend.down{color:var(--color-error)}.stat-card-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--foreground);line-height:var(--leading-none)}.stat-card--primary .stat-card-icon{background-color:var(--color-primary-subtle);color:var(--color-primary)}.stat-card--success .stat-card-icon{background-color:var(--color-success-subtle);color:var(--color-success)}.stat-card--warning .stat-card-icon{background-color:var(--color-warning-subtle);color:var(--color-warning)}.stat-card--error .stat-card-icon{background-color:var(--color-error-subtle);color:var(--color-error)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-0-5) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);line-height:var(--leading-normal);border-radius:var(--radius-md);white-space:nowrap}.badge-dot:before{content:"";width:6px;height:6px;border-radius:var(--radius-full);background-color:currentColor}.badge-default{background-color:var(--background-tertiary);color:var(--foreground-secondary)}.badge-primary{background-color:var(--color-primary-subtle);color:var(--color-primary)}.badge-success{background-color:var(--color-success-subtle);color:var(--color-success)}.badge-warning{background-color:var(--color-warning-subtle);color:var(--color-warning)}.badge-error{background-color:var(--color-error-subtle);color:var(--color-error)}.badge-info{background-color:var(--color-info-subtle);color:var(--color-info)}.badge-outline{background-color:transparent;border:1px solid currentColor}.badge-sm{padding:var(--space-0-5) var(--space-1-5);font-size:10px}.badge-lg{padding:var(--space-1) var(--space-3);font-size:var(--text-sm)}.status{display:inline-flex;align-items:center;gap:var(--space-1-5);padding:var(--space-1) var(--space-2-5);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full)}.status-dot{width:6px;height:6px;border-radius:var(--radius-full);flex-shrink:0}.status--draft,.status--editee{background-color:var(--background-tertiary);color:var(--foreground-secondary)}.status--draft .status-dot,.status--editee .status-dot{background-color:var(--foreground-muted)}.status--validated,.status--validee{background-color:var(--color-info-subtle);color:var(--color-info)}.status--validated .status-dot,.status--validee .status-dot{background-color:var(--color-info)}.status--sent,.status--envoyee{background-color:#8b5cf61a;color:#7c3aed}.status--sent .status-dot,.status--envoyee .status-dot{background-color:#7c3aed}.status--paid,.status--payee,.status--success{background-color:var(--color-success-subtle);color:var(--color-success)}.status--paid .status-dot,.status--payee .status-dot,.status--success .status-dot{background-color:var(--color-success)}.status--cancelled,.status--annulee,.status--error{background-color:var(--color-error-subtle);color:var(--color-error)}.status--cancelled .status-dot,.status--annulee .status-dot,.status--error .status-dot{background-color:var(--color-error)}.status--pending,.status--en-attente,.status--warning{background-color:var(--color-warning-subtle);color:var(--color-warning)}.status--pending .status-dot,.status--en-attente .status-dot,.status--warning .status-dot{background-color:var(--color-warning)}.table-container{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-xl);background-color:var(--card)}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--foreground-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide);background-color:var(--background-secondary);border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);color:var(--foreground);border-bottom:1px solid var(--border);vertical-align:middle}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--interactive-hover)}.table tbody tr.selected{background-color:var(--interactive-selected)}.table tbody tr.clickable{cursor:pointer}.table .text-right{text-align:right}.table .text-center{text-align:center}.table-compact th,.table-compact td{padding:var(--space-2) var(--space-3)}.table-relaxed th,.table-relaxed td{padding:var(--space-4) var(--space-5)}.table-striped tbody tr:nth-child(2n){background-color:var(--background-secondary)}.table-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center;color:var(--foreground-muted)}.table-empty-icon{width:48px;height:48px;margin-bottom:var(--space-4);color:var(--foreground-subtle)}.table-empty-title{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--foreground);margin-bottom:var(--space-1)}.table-empty-description{font-size:var(--text-sm);color:var(--foreground-muted);max-width:300px}.modal-overlay{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--space-4);background-color:var(--background-backdrop);animation:fadeIn var(--duration-normal) var(--ease-out)}.modal{position:relative;width:100%;max-width:500px;max-height:calc(100vh - var(--space-8));display:flex;flex-direction:column;background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);animation:scaleIn var(--duration-slow) var(--ease-out)}.modal-sm{max-width:400px}.modal-md{max-width:500px}.modal-lg{max-width:700px}.modal-xl{max-width:900px}.modal-2xl{max-width:1100px}.modal-full{max-width:calc(100vw - var(--space-8))}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--border)}.modal-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--foreground)}.modal-subtitle{font-size:var(--text-sm);color:var(--foreground-muted);margin-top:var(--space-0-5)}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-md);background-color:transparent;color:var(--foreground-muted);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--interactive-hover);color:var(--foreground)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border);background-color:var(--background-secondary)}.modal-footer-left{justify-content:space-between}.split-modal{max-width:1200px}.split-modal .modal-body{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0}.split-modal-form{padding:var(--space-5);overflow-y:auto;border-right:1px solid var(--border)}.split-modal-preview{padding:var(--space-5);overflow-y:auto;background-color:var(--background-secondary)}.split-modal-preview-title{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--foreground-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-bottom:var(--space-4)}@media(max-width:1024px){.split-modal .modal-body{grid-template-columns:1fr}.split-modal-form{border-right:none;border-bottom:1px solid var(--border)}.split-modal-preview{max-height:400px}}.tabs{display:flex;flex-direction:column;gap:var(--space-4)}.tabs-list{display:flex;gap:var(--space-1);padding:var(--space-1);background-color:var(--background-secondary);border-radius:var(--radius-lg)}.tabs-trigger{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--foreground-muted);background-color:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.tabs-trigger:hover{color:var(--foreground)}.tabs-trigger[data-state=active],.tabs-trigger.active{background-color:var(--card);color:var(--foreground);box-shadow:var(--shadow-sm)}.tabs-content{display:none}.tabs-content[data-state=active],.tabs-content.active{display:block;animation:fadeIn var(--duration-normal) var(--ease-out)}.tabs-underline .tabs-list{background-color:transparent;padding:0;gap:var(--space-6);border-bottom:1px solid var(--border);border-radius:0}.tabs-underline .tabs-trigger{flex:none;padding:var(--space-3) 0;border-radius:0;border-bottom:2px solid transparent;margin-bottom:-1px}.tabs-underline .tabs-trigger[data-state=active],.tabs-underline .tabs-trigger.active{background-color:transparent;color:var(--color-primary);border-bottom-color:var(--color-primary);box-shadow:none}.dropdown{position:relative}.dropdown-trigger{cursor:pointer}.dropdown-content{position:absolute;top:100%;right:0;z-index:var(--z-dropdown);min-width:180px;margin-top:var(--space-1);padding:var(--space-1);background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:slideInDown var(--duration-normal) var(--ease-out)}.dropdown-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--foreground);background-color:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast);text-align:left;text-decoration:none}.dropdown-item:hover{background-color:var(--interactive-hover)}.dropdown-item-destructive{color:var(--color-error)}.dropdown-item-destructive:hover{background-color:var(--color-error-subtle)}.dropdown-separator{height:1px;margin:var(--space-1) 0;background-color:var(--border)}.dropdown-label{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--foreground-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.avatar{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background-color:var(--color-primary-subtle);color:var(--color-primary);font-weight:var(--font-semibold);font-size:var(--text-sm);overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-xs{width:24px;height:24px;font-size:var(--text-xs)}.avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar-lg{width:48px;height:48px;font-size:var(--text-base)}.avatar-xl{width:64px;height:64px;font-size:var(--text-lg)}.avatar-status{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:var(--radius-full);border:2px solid var(--card)}.avatar-status-online{background-color:var(--color-success)}.avatar-status-offline{background-color:var(--foreground-muted)}.avatar-status-busy{background-color:var(--color-error)}.skeleton{background:linear-gradient(90deg,var(--background-tertiary) 25%,var(--background-secondary) 50%,var(--background-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-text{height:14px;width:100%}.skeleton-title{height:24px;width:60%}.skeleton-avatar{width:40px;height:40px;border-radius:var(--radius-full)}.skeleton-card{height:120px;border-radius:var(--radius-xl)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);text-align:center}.empty-state-icon{width:64px;height:64px;margin-bottom:var(--space-4);color:var(--foreground-subtle)}.empty-state-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--foreground);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--text-sm);color:var(--foreground-muted);max-width:360px;margin-bottom:var(--space-6)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm)}.alert-icon{flex-shrink:0;width:20px;height:20px}.alert-content{flex:1}.alert-title{font-weight:var(--font-medium);margin-bottom:var(--space-0-5)}.alert-description{color:inherit;opacity:.9}.alert-info{background-color:var(--color-info-subtle);color:var(--color-info)}.alert-success{background-color:var(--color-success-subtle);color:var(--color-success)}.alert-warning{background-color:var(--color-warning-subtle);color:var(--color-warning)}.alert-error{background-color:var(--color-error-subtle);color:var(--color-error)}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin .8s linear infinite}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-lg{width:32px;height:32px;border-width:3px}.spinner-xl{width:48px;height:48px;border-width:4px}.loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:var(--background-overlay);border-radius:inherit;z-index:10}.tooltip{position:relative}.tooltip-content{position:absolute;z-index:var(--z-tooltip);bottom:100%;left:50%;transform:translate(-50%);margin-bottom:var(--space-2);padding:var(--space-1-5) var(--space-2-5);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--foreground-inverse);background-color:var(--foreground);border-radius:var(--radius-md);white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;transition:opacity var(--transition-fast),visibility var(--transition-fast)}.tooltip:hover .tooltip-content{opacity:1;visibility:visible}.divider{width:100%;height:1px;background-color:var(--border);margin:var(--space-4) 0}.divider-vertical{width:1px;height:100%;margin:0 var(--space-4)}.divider-text{display:flex;align-items:center;gap:var(--space-4);color:var(--foreground-muted);font-size:var(--text-sm)}.divider-text:before,.divider-text:after{content:"";flex:1;height:1px;background-color:var(--border)}.progress{width:100%;height:8px;background-color:var(--background-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background-color:var(--color-primary);border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-sm{height:4px}.progress-lg{height:12px}.search-box-input{width:100%;padding:var(--space-2) var(--space-4);padding-left:var(--space-10);font-size:var(--text-sm);color:var(--foreground);background-color:var(--input-background);border:1px solid var(--input-border);border-radius:var(--radius-lg);outline:none;transition:all var(--transition-fast)}.search-box-input::placeholder{color:var(--input-placeholder)}.search-box-input:focus{border-color:var(--input-border-focus);box-shadow:0 0 0 var(--ring-width) var(--ring-color)}.search-box-icon{position:absolute;left:var(--space-3);color:var(--foreground-muted);pointer-events:none}.search-box-clear{position:absolute;right:var(--space-2);display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:var(--radius-md);background-color:transparent;color:var(--foreground-muted);cursor:pointer;transition:all var(--transition-fast)}.search-box-clear:hover{background-color:var(--interactive-hover);color:var(--foreground)}.command-palette{position:fixed;top:20%;left:50%;transform:translate(-50%);width:100%;max-width:640px;z-index:var(--z-modal)}.command-input{width:100%;padding:var(--space-4) var(--space-5);font-size:var(--text-base);background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl)}.command-list{max-height:400px;overflow-y:auto;margin-top:var(--space-2);padding:var(--space-2);background-color:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl)}.command-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);cursor:pointer;transition:background-color var(--transition-fast)}.command-item:hover,.command-item[data-selected=true]{background-color:var(--interactive-hover)}.page-enter{opacity:0;transform:translateY(8px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .2s ease-out,transform .2s ease-out}.focus-trap:focus{outline:none}.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}.scrollbar-hide::-webkit-scrollbar{display:none}.scrollbar-thin{scrollbar-width:thin}.scrollbar-thin::-webkit-scrollbar{width:6px;height:6px}.scrollbar-thin::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}.hidden-mobile{display:block}.hidden-desktop{display:none}@media(max-width:768px){.hidden-mobile{display:none!important}.hidden-desktop{display:block!important}.page-container{padding:var(--space-3)}.modal{max-width:100%;max-height:100%;border-radius:0}}@media print{.no-print,.sidebar,.header,.modal-overlay,.toast-container{display:none!important}body{background:#fff!important;color:#000!important}.main-content{margin-left:0!important}.card,.table-container{page-break-inside:avoid}a[href]:after{content:" (" attr(href) ")";font-size:.8em;color:#666}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media(prefers-contrast:high){:root{--border: var(--foreground-muted);--input-border: var(--foreground-muted)}}.skip-to-content{position:absolute;top:-100%;left:var(--space-4);padding:var(--space-2) var(--space-4);background-color:var(--color-primary);color:var(--color-primary-foreground);border-radius:var(--radius-md);z-index:var(--z-skipLink);transition:top var(--transition-fast)}.skip-to-content:focus{top:var(--space-4)}.js-focus-visible :focus:not(.focus-visible){outline:none;box-shadow:none}.js-focus-visible .focus-visible{outline:none;box-shadow:0 0 0 var(--ring-offset) var(--background),0 0 0 calc(var(--ring-offset) + var(--ring-width)) var(--ring-color)}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width, 260px);height:100vh;background:var(--background);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:var(--z-sidebar, 40);transition:transform var(--transition-base)}.sidebar-header{padding:var(--space-5) var(--space-4);border-bottom:1px solid var(--border-subtle)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3)}.logo-icon{width:40px;height:40px;background:var(--color-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-icon span{font-family:var(--font-display);font-weight:var(--font-bold);font-size:var(--text-base);color:var(--color-primary-foreground);letter-spacing:-.02em}.logo-text{display:flex;flex-direction:column;min-width:0}.logo-name{font-family:var(--font-display);font-weight:var(--font-semibold);font-size:var(--text-base);color:var(--foreground);letter-spacing:-.01em;line-height:1.2}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-3)}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--foreground-muted)}.nav-section{margin-bottom:var(--space-6)}.nav-section:last-child{margin-bottom:0}.nav-section-label{display:block;font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--foreground-muted);text-transform:uppercase;letter-spacing:.05em;padding:0 var(--space-3);margin-bottom:var(--space-2)}.nav-list{list-style:none;margin:0;padding:0}.nav-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2-5) var(--space-3);margin-bottom:2px;background:transparent;border:none;border-radius:var(--radius-lg);color:var(--foreground-secondary);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);text-align:left;cursor:pointer;transition:all var(--transition-fast)}.nav-item:hover{background:var(--background-tertiary);color:var(--foreground)}.nav-item--active,.nav-item--active:hover{background:var(--color-primary-subtle);color:var(--color-primary)}.nav-item svg{flex-shrink:0;opacity:.7;transition:opacity var(--transition-fast)}.nav-item:hover svg,.nav-item--active svg{opacity:1}.nav-item-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item-badge{background:var(--color-primary);color:var(--color-primary-foreground);font-size:12px;font-weight:var(--font-semibold);padding:3px 8px;border-radius:var(--radius-full);min-width:22px;text-align:center;line-height:1.3;letter-spacing:-.01em;box-shadow:0 1px 2px #0000001a}.sidebar-footer{padding:var(--space-3);border-top:1px solid var(--border-subtle);background:var(--background-secondary)}.nav-list--secondary{margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle)}.nav-list--secondary .nav-item{color:var(--foreground-muted);font-size:var(--text-sm);padding:var(--space-2) var(--space-3)}.nav-list--secondary .nav-item:hover{color:var(--foreground-secondary)}.theme-toggle{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-3);background:transparent;border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--foreground-secondary);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.theme-toggle:hover{background:var(--background-tertiary);border-color:var(--border-hover);color:var(--foreground)}.theme-toggle svg{flex-shrink:0;color:var(--foreground-muted)}.sidebar-user{position:relative}.user-trigger{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2-5) var(--space-3);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.user-trigger:hover{background:var(--background-tertiary);border-color:var(--border-hover)}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-avatar span{font-weight:var(--font-semibold);font-size:var(--text-sm);color:var(--color-primary-foreground)}.user-info{flex:1;display:flex;flex-direction:column;min-width:0;text-align:left}.user-name{font-weight:var(--font-medium);font-size:var(--text-sm);color:var(--foreground);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:var(--text-xs);color:var(--foreground-muted);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-chevron{flex-shrink:0;color:var(--foreground-muted);transition:transform var(--transition-fast)}.user-chevron--open{transform:rotate(180deg)}.user-menu-overlay{position:fixed;inset:0;z-index:var(--z-popover, 50)}.user-menu{position:absolute;bottom:calc(100% + var(--space-2));left:0;right:0;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:calc(var(--z-popover, 50) + 1);overflow:hidden;animation:slideUp .15s ease-out}.user-menu-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle)}.user-menu-email{font-size:var(--text-sm);color:var(--foreground-secondary);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-divider{height:1px;background:var(--border-subtle);margin:var(--space-1) 0}.user-menu-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2-5) var(--space-4);background:transparent;border:none;color:var(--foreground-secondary);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-normal);text-align:left;cursor:pointer;transition:all var(--transition-fast)}.user-menu-item:hover{background:var(--background-tertiary);color:var(--foreground)}.user-menu-item svg{flex-shrink:0;color:var(--foreground-muted)}.user-menu-item:hover svg{color:var(--foreground-secondary)}.user-menu-item--danger{color:var(--color-error)}.user-menu-item--danger:hover{background:var(--color-error-subtle);color:var(--color-error)}.user-menu-item--danger svg{color:var(--color-error)}@media(max-width:768px){.sidebar{transform:translate(-100%);box-shadow:none}.sidebar.sidebar--open{transform:translate(0);box-shadow:var(--shadow-2xl)}}[data-theme=dark] .sidebar{background:var(--background);border-color:var(--border)}[data-theme=dark] .logo-icon{box-shadow:0 0 0 1px #ffffff1a}[data-theme=dark] .user-trigger{background:var(--background-secondary)}[data-theme=dark] .user-menu{background:var(--background-secondary);box-shadow:var(--shadow-2xl)}[data-theme=dark] .theme-toggle{background:var(--background-secondary)}[data-theme=dark] .nav-item-badge{box-shadow:0 1px 3px #0000004d,0 0 0 1px #ffffff0d}.header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--background);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:var(--z-sticky)}.header-left{flex-shrink:0}.header-titles{display:flex;flex-direction:column;gap:var(--space-0-5)}.header-title{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--foreground);margin:0;line-height:1.2;letter-spacing:-.01em}.header-subtitle{font-size:var(--text-sm);color:var(--foreground-muted);margin:0}.header-center{flex:1;max-width:480px;margin:0 var(--space-4)}.search-box{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:var(--space-3);color:var(--foreground-muted);pointer-events:none}.search-input{width:100%;padding:var(--space-2-5) var(--space-3);padding-left:calc(var(--space-3) + 24px);padding-right:calc(var(--space-3) + 48px);font-family:var(--font-body);font-size:var(--text-sm);color:var(--foreground);background:var(--background-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);outline:none;transition:all var(--transition-fast)}.search-input::placeholder{color:var(--foreground-muted)}.search-input:hover{border-color:var(--border-hover)}.search-input:focus{background:var(--background);border-color:var(--color-primary);box-shadow:0 0 0 var(--ring-offset) var(--background),0 0 0 calc(var(--ring-offset) + var(--ring-width)) var(--ring-color)}.search-shortcut{position:absolute;right:var(--space-3);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-family:var(--font-body);color:var(--foreground-muted);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);line-height:1}.header-right{display:flex;align-items:center;gap:var(--space-4);flex-shrink:0}.header-datetime{display:flex;flex-direction:column;align-items:flex-end;padding-right:var(--space-4);border-right:1px solid var(--border)}.header-time{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--foreground);line-height:1.2;font-variant-numeric:tabular-nums}.header-date{font-size:var(--text-xs);color:var(--foreground-muted);text-transform:capitalize}.header-actions{display:flex;align-items:center;gap:var(--space-2)}.header-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--foreground-secondary);cursor:pointer;transition:all var(--transition-fast)}.header-btn:hover{background:var(--background-tertiary);color:var(--foreground);border-color:var(--border-hover)}.header-btn--active{background:var(--color-primary-subtle);color:var(--color-primary);border-color:var(--color-primary)}.notification-wrapper{position:relative}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-primary-foreground);background:var(--color-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;line-height:1}.notification-overlay{position:fixed;inset:0;z-index:var(--z-popover)}.notification-dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;width:340px;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden;z-index:calc(var(--z-popover) + 1);animation:slideDown .15s ease-out}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.notification-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--foreground)}.notification-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--foreground-muted);cursor:pointer;transition:all var(--transition-fast)}.notification-close:hover{background:var(--background-tertiary);color:var(--foreground)}.notification-list{max-height:320px;overflow-y:auto}.notification-item{display:flex;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background var(--transition-fast)}.notification-item:hover{background:var(--background-tertiary)}.notification-item:last-child{border-bottom:none}.notification-item--unread{background:var(--color-primary-subtle)}.notification-item--unread:hover{background:var(--interactive-hover)}.notification-dot{width:8px;height:8px;background:var(--color-primary);border-radius:var(--radius-full);margin-top:6px;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-text{font-size:var(--text-sm);color:var(--foreground);margin:0 0 var(--space-1) 0;font-weight:var(--font-medium);line-height:1.4}.notification-time{font-size:var(--text-xs);color:var(--foreground-muted)}.notification-empty{padding:var(--space-8) var(--space-4);text-align:center}.notification-empty p{font-size:var(--text-sm);color:var(--foreground-muted);margin:0}.notification-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);background:var(--background-secondary)}.notification-action{width:100%;padding:var(--space-2);background:transparent;border:none;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-primary);cursor:pointer;transition:color var(--transition-fast)}.notification-action:hover{color:var(--color-primary-hover);text-decoration:underline}@media(max-width:1024px){.header-center,.header-datetime{display:none}}@media(max-width:768px){.header{padding:var(--space-3) var(--space-4)}.header-title{font-size:var(--text-xl)}.header-subtitle{font-size:var(--text-xs)}.notification-dropdown{position:fixed;inset:auto 0 0;width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:70vh}}[data-theme=dark] .header{background:var(--background);border-color:var(--border)}[data-theme=dark] .search-input,[data-theme=dark] .notification-dropdown{background:var(--background-secondary)}.stat-card{position:relative;background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-5);transition:all var(--transition-normal);animation:fadeIn var(--duration-slow) var(--ease-out) backwards}.stat-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.stat-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-4)}.stat-icon{width:44px;height:44px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;background:var(--color-primary-subtle);color:var(--color-primary);flex-shrink:0}.stat-card--primary .stat-icon{background:var(--color-primary-subtle);color:var(--color-primary)}.stat-card--success .stat-icon{background:var(--color-success-subtle);color:var(--color-success)}.stat-card--warning .stat-icon{background:var(--color-warning-subtle);color:var(--color-warning)}.stat-card--info .stat-icon{background:var(--color-info-subtle);color:var(--color-info)}.stat-trend{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold)}.stat-trend--up{background:var(--color-success-subtle);color:var(--color-success)}.stat-trend--down{background:var(--color-error-subtle);color:var(--color-error)}.stat-card-body{display:flex;flex-direction:column;gap:var(--space-1)}.stat-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--foreground);line-height:1.1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.stat-title{font-size:var(--text-sm);color:var(--foreground-muted);font-weight:var(--font-medium)}.stat-card-footer{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-subtle)}.stat-trend-label{font-size:var(--text-xs);color:var(--foreground-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.stat-card{padding:var(--space-4)}.stat-value{font-size:var(--text-2xl)}.stat-icon{width:40px;height:40px}}[data-theme=dark] .stat-card{background:var(--card);border-color:var(--card-border)}[data-theme=dark] .stat-card:hover{border-color:var(--border-secondary)}.chart-container{background:var(--card);border-radius:var(--radius-xl);overflow:hidden}.chart-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle)}.chart-header h3{margin:0;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--foreground)}.chart-legend{display:flex;gap:var(--space-4)}.legend-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--foreground-muted)}.legend-dot{width:10px;height:10px;background:var(--color-primary);border-radius:var(--radius-sm)}.legend-dot.success{background:var(--color-success)}.legend-dot.warning{background:var(--color-warning)}.legend-dot.info{background:var(--color-info)}.chart-wrapper{padding:var(--space-5);height:280px}.chart-wrapper canvas{width:100%;height:100%}@media(max-width:768px){.chart-wrapper{height:220px;padding:var(--space-4)}.chart-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.chart-legend{flex-wrap:wrap;gap:var(--space-2)}}[data-theme=dark] .chart-container{background:var(--card)}.delivery-table-container{background:var(--card);border-radius:var(--radius-xl);overflow:hidden}.table-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle)}.table-header h3{margin:0;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--foreground)}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.table thead{background:var(--background-secondary)}.table th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-medium);color:var(--foreground-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.table td{padding:var(--space-3) var(--space-4);color:var(--foreground-secondary);border-bottom:1px solid var(--border-subtle)}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--interactive-hover)}.table tbody tr:last-child td{border-bottom:none}.delivery-id{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-primary);background:var(--color-primary-subtle);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md)}.client-name{font-weight:var(--font-medium);color:var(--foreground)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);white-space:nowrap}.badge-success{background:var(--color-success-subtle);color:var(--color-success)}.badge-warning{background:var(--color-warning-subtle);color:var(--color-warning)}.badge-info{background:var(--color-info-subtle);color:var(--color-info)}.badge-error{background:var(--color-error-subtle);color:var(--color-error)}@media(max-width:768px){.table-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.table th,.table td{padding:var(--space-2) var(--space-3)}.table th:nth-child(3),.table td:nth-child(3),.table th:nth-child(4),.table td:nth-child(4){display:none}}[data-theme=dark] .delivery-table-container{background:var(--card)}[data-theme=dark] .table thead{background:var(--background-tertiary)}.dashboard{min-height:100vh;background:var(--background-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.dashboard-chart,.dashboard-table{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);overflow:hidden}@media(max-width:1400px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1200px){.dashboard-grid{grid-template-columns:1fr}}@media(max-width:768px){.stats-grid{grid-template-columns:1fr}.page-content{padding:var(--space-4)}}[data-theme=dark] .dashboard{background:var(--background)}[data-theme=dark] .dashboard-chart,[data-theme=dark] .dashboard-table{background:var(--card);border-color:var(--card-border)}.modal-backdrop{position:fixed;inset:0;background:var(--bg-overlay);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--space-4)}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-xl);max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-small{width:100%;max-width:400px}.modal-medium{width:100%;max-width:560px}.modal-large{width:100%;max-width:720px}.modal-xlarge{width:100%;max-width:900px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border-color);background:var(--bg-surface)}.modal-header h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0;color:var(--text-primary)}.modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:10px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-surface-hover);color:var(--text-primary);border-color:var(--border-color-hover)}.modal-content{padding:var(--space-6);overflow-y:auto;flex:1}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track{background:transparent}.modal-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-6);border-top:1px solid var(--border-color);background:var(--bg-surface)}@media(max-width:768px){.modal-backdrop{padding:var(--space-3)}.modal{max-height:95vh}.modal-header,.modal-content,.modal-footer{padding:var(--space-4)}.modal-small,.modal-medium,.modal-large,.modal-xlarge{max-width:100%}}.form-stepper{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-bottom:var(--space-6);padding-bottom:var(--space-6);border-bottom:1px solid var(--border-color)}.stepper-step{display:flex;align-items:center;gap:var(--space-2)}.step-number{width:32px;height:32px;border-radius:var(--radius-full);background:var(--bg-surface);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--text-muted);transition:all var(--transition-fast)}.stepper-step.active .step-number{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.stepper-step.completed .step-number{background:var(--color-success);border-color:var(--color-success);color:#fff}.step-label{font-size:var(--font-size-sm);color:var(--text-muted);font-weight:var(--font-weight-medium)}.stepper-step.active .step-label{color:var(--text-primary)}.stepper-line{width:40px;height:2px;background:var(--border-color)}.form-step{min-height:280px}.step-description{color:var(--text-secondary);margin-bottom:var(--space-6)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary)}.process-options{display:flex;flex-direction:column;gap:var(--space-3)}.process-option{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-6);background:var(--bg-surface);border:2px solid var(--border-color);border-radius:16px;cursor:pointer;transition:all var(--transition-fast)}.process-option:hover{border-color:var(--border-color-hover);background:var(--bg-surface-hover)}.process-option.selected{border-color:var(--color-primary);background:#3b82f60d}.option-radio{width:24px;height:24px;border-radius:var(--radius-full);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast)}.process-option.selected .option-radio{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.option-content{display:flex;flex-direction:column}.option-name{font-weight:600;color:var(--text-primary)}.option-desc{font-size:var(--font-size-sm);color:var(--text-muted)}.button-group{display:flex;gap:var(--space-2);flex-wrap:wrap}.btn-option{padding:var(--space-2) var(--space-4);background:var(--bg-surface);border:2px solid var(--border-color);border-radius:10px;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.btn-option:hover{border-color:var(--border-color-hover);background:var(--bg-surface-hover)}.btn-option.selected{border-color:var(--color-primary);background:#3b82f61a;color:var(--color-primary)}@media(max-width:640px){.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}.form-stepper{flex-wrap:wrap}.step-label{display:none}}.client-type-options{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6)}.client-type-option{display:flex;align-items:center;gap:var(--space-6);padding:var(--space-6);background:var(--bg-surface);border:2px solid var(--border-color);border-radius:16px;cursor:pointer;transition:all var(--transition-fast)}.client-type-option:hover{border-color:var(--border-color-hover);background:var(--bg-surface-hover)}.client-type-option.selected{border-color:var(--color-primary);background:#3b82f60d}.client-type-option .type-icon{font-size:var(--font-size-3xl);width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:16px;flex-shrink:0}.client-type-option.selected .type-icon{background:#3b82f61a}.client-type-option .type-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.client-type-option .type-name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg);color:var(--text-primary)}.client-type-option .type-desc{font-size:var(--font-size-sm);color:var(--text-muted)}.client-type-option .type-radio{width:28px;height:28px;border-radius:var(--radius-full);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast)}.client-type-option.selected .type-radio{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.type-info-panel{background:var(--bg-secondary);border-radius:16px;padding:var(--space-6);border:1px solid var(--border-color)}.type-info-panel h4{margin:0 0 var(--space-4) 0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.type-info-panel ul{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.type-info-panel li{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--text-secondary)}.type-info-panel li svg{color:var(--color-success);flex-shrink:0}@media(max-width:640px){.type-info-panel ul{grid-template-columns:1fr}.client-type-option{padding:var(--space-4)}.client-type-option .type-icon{width:44px;height:44px;font-size:var(--font-size-2xl)}}.tournee-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-grid.cols-3{grid-template-columns:repeat(3,1fr)}.form-group.full-width{grid-column:span 2}.jours-grid{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.jour-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:.85rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.jour-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.jour-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.vehicule-options{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.vehicule-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.vehicule-option:hover{border-color:var(--text-muted)}.vehicule-option.selected{border-color:var(--color-primary);background:#3b82f60d}.vehicule-option input{display:none}.vehicule-content{display:flex;flex-direction:column}.vehicule-title{font-weight:600;color:var(--text-primary)}.vehicule-desc{font-size:.8rem;color:var(--text-muted)}@media(max-width:600px){.form-grid,.form-grid.cols-3{grid-template-columns:1fr}.form-group.full-width{grid-column:auto}.vehicule-options{grid-template-columns:1fr}}.livreur-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-section{padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.form-section:last-child{border-bottom:none;padding-bottom:0}.form-section h3{margin:0 0 var(--spacing-md) 0;font-size:.9rem;font-weight:600;color:var(--text-primary)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.textarea{resize:vertical;min-height:80px}.paiement-options{display:flex;flex-direction:column;gap:var(--spacing-sm)}.paiement-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.paiement-option:hover{border-color:var(--text-muted)}.paiement-option.selected{border-color:var(--color-primary);background:#3b82f60d}.paiement-option input{display:none}.paiement-content{display:flex;flex-direction:column}.paiement-title{font-weight:600;color:var(--text-primary)}.paiement-desc{font-size:.8rem;color:var(--text-muted)}.permis-grid{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.permis-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:.85rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.permis-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.permis-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}@media(max-width:600px){.form-grid{grid-template-columns:1fr}}.confirm-modal-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-lg) 0}.confirm-icon{width:64px;height:64px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-lg)}.confirm-icon.danger{background:#ef44441a;color:#ef4444}.confirm-icon.warning{background:#eab3081a;color:#eab308}.confirm-message{margin:0;font-size:.95rem;color:var(--text-secondary);line-height:1.5}.btn-danger{background:#ef4444;color:#fff;border:none}.btn-danger:hover{background:#dc2626}.vp-dashboard{min-height:100vh;background:var(--bg-primary)}.vp-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--bg-card);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:var(--z-sticky);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.vp-header-left{display:flex;align-items:center;gap:1rem}.vp-back-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-color);border-radius:10px;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.vp-back-btn:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--text-muted)}.vp-brand h1{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.vp-date{font-size:.8rem;color:var(--text-muted);text-transform:capitalize;margin-top:2px}.vp-header-actions{display:flex;gap:.75rem}.vp-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;border:none;white-space:nowrap}.vp-btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-md)}.vp-btn-primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.vp-btn-secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.vp-btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.vp-btn-icon{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-muted);cursor:pointer;transition:all .2s ease}.vp-btn-icon:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.vp-content{padding:1.5rem;max-width:1500px;margin:0 auto}.vp-stats-section{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.vp-stat-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;transition:all .25s ease}.vp-stat-card:hover{border-color:var(--border-color-hover, var(--text-muted));box-shadow:0 4px 20px #00000014}.vp-stat-card.highlight{background:linear-gradient(135deg,var(--color-primary) 0%,var(--primary-600) 100%);border:none}.vp-stat-card.highlight .vp-stat-label,.vp-stat-card.highlight .vp-stat-sub{color:#ffffffbf}.vp-stat-card.highlight .vp-stat-value{color:#fff}.vp-stat-card.highlight .vp-stat-icon{background:#ffffff26;color:#fff}.vp-stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px;flex-shrink:0}.vp-stat-icon.blue{background:#3b82f61a;color:#3b82f6}.vp-stat-icon.green{background:#22c55e1a;color:#22c55e}.vp-stat-icon.purple{background:#a855f71a;color:#a855f7}.vp-stat-info{display:flex;flex-direction:column;gap:2px;min-width:0}.vp-stat-label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.vp-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.1}.vp-stat-sub{font-size:.75rem;color:var(--text-muted)}.vp-main-grid{display:grid;grid-template-columns:1fr 380px;gap:1.5rem}.vp-left-column,.vp-right-column{display:flex;flex-direction:column;gap:1rem}.vp-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden}.vp-card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.vp-card-header h2{margin:0;font-size:.9rem;font-weight:600;color:var(--text-primary)}.vp-card-subtitle{font-size:.75rem;color:var(--text-muted)}.vp-card-badge{font-size:.7rem;font-weight:500;padding:4px 10px;background:#3b82f614;border-radius:20px;color:var(--color-primary)}.vp-chart-card{padding-bottom:1rem}.vp-chart{padding:1.5rem 1.25rem 1rem}.vp-chart-bars{display:flex;justify-content:space-between;align-items:flex-end;height:180px;gap:.75rem;padding:0 .5rem}.vp-chart-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}.vp-chart-bar-container{width:100%;height:140px;display:flex;align-items:flex-end;justify-content:center}.vp-chart-bar{width:100%;max-width:40px;min-height:6px;background:linear-gradient(180deg,var(--color-primary) 0%,rgba(59,130,246,.4) 100%);border-radius:var(--radius-md) var(--radius-md) var(--radius-sm) var(--radius-sm);position:relative;transition:var(--transition-base);cursor:pointer}.vp-chart-bar:hover{filter:brightness(1.15);transform:scaleX(1.08)}.vp-chart-bar-value{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);font-size:.7rem;font-weight:600;color:var(--text-primary);white-space:nowrap;background:var(--bg-card);padding:3px 6px;border-radius:4px;box-shadow:0 2px 8px #0000001a;opacity:0;pointer-events:none;transition:opacity .2s ease}.vp-chart-bar:hover .vp-chart-bar-value{opacity:1}.vp-chart-label{font-size:.7rem;color:var(--text-muted);text-transform:capitalize;font-weight:500}.vp-planning{padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.vp-planning-item{display:grid;grid-template-columns:16px 1fr auto auto;gap:1rem;align-items:center;padding:.875rem 1rem;border-radius:12px;background:var(--bg-secondary);cursor:pointer;transition:all .2s ease;border:1px solid transparent}.vp-planning-item:hover{background:var(--bg-hover);border-color:var(--border-color)}.vp-planning-status{display:flex;justify-content:center}.vp-status-indicator{width:8px;height:8px;border-radius:50%}.vp-status-indicator.info{background:#3b82f6;box-shadow:0 0 0 3px #3b82f633;animation:pulse 2s infinite}.vp-status-indicator.success{background:#22c55e}.vp-status-indicator.secondary{background:var(--text-muted)}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #3b82f633}50%{box-shadow:0 0 0 6px #3b82f61a}}.vp-planning-content{min-width:0}.vp-planning-top{display:flex;align-items:center;gap:.5rem;margin-bottom:4px}.vp-planning-top h3{margin:0;font-size:.9rem;font-weight:600;color:var(--text-primary)}.vp-planning-ref{font-size:.65rem;font-family:SF Mono,monospace;color:var(--color-primary);background:#3b82f614;padding:2px 6px;border-radius:var(--radius-sm);font-weight:500}.vp-planning-meta{display:flex;gap:1rem}.vp-planning-time,.vp-planning-vehicle{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted)}.vp-planning-time svg,.vp-planning-vehicle svg{opacity:.6}.vp-planning-livreur{display:flex;align-items:center;gap:.5rem}.vp-avatar{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;font-size:.75rem;font-weight:600;flex-shrink:0}.vp-avatar.small{width:26px;height:26px;font-size:.65rem}.vp-livreur-info{display:flex;flex-direction:column;min-width:0}.vp-livreur-name{font-size:.8rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vp-livreur-phone{font-size:.7rem;color:var(--text-muted);text-decoration:none;transition:color .2s ease}.vp-livreur-phone:hover{color:var(--color-primary)}.vp-planning-amount{font-size:.95rem;font-weight:700;color:var(--color-primary);text-align:right;padding-left:.5rem}.vp-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-muted);text-align:center}.vp-empty-state svg{opacity:.4}.vp-empty-state p{margin:1rem 0 0;font-size:.85rem}.vp-tournees-list{padding:.5rem;display:flex;flex-direction:column;gap:.25rem;max-height:320px;overflow-y:auto}.vp-tournee-item{display:grid;grid-template-columns:1fr auto auto;gap:.75rem;align-items:center;padding:.75rem 1rem;border-radius:10px;transition:background .2s ease;cursor:pointer}.vp-tournee-item:hover{background:var(--bg-secondary)}.vp-tournee-main{min-width:0}.vp-tournee-header{display:flex;align-items:center;gap:.5rem;margin-bottom:2px}.vp-tournee-ref{font-size:.65rem;font-family:monospace;color:var(--color-primary);font-weight:500}.vp-tournee-badge{font-size:.6rem;font-weight:500;padding:1px 5px;border-radius:4px}.vp-tournee-badge.active{background:#22c55e1a;color:#22c55e}.vp-tournee-badge.inactive{background:#eab3081a;color:#eab308}.vp-tournee-main h4{margin:0 0 2px;font-size:.85rem;font-weight:600;color:var(--text-primary)}.vp-tournee-details{display:flex;gap:.75rem;font-size:.75rem;color:var(--text-muted)}.vp-tournee-tarif{font-weight:600;color:var(--color-primary)}.vp-tournee-livreur{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-secondary)}.vp-livreurs-list{padding:.5rem;display:flex;flex-direction:column;gap:.25rem;max-height:280px;overflow-y:auto}.vp-livreur-item{display:grid;grid-template-columns:auto 1fr auto;gap:.75rem;align-items:center;padding:.625rem .75rem;border-radius:10px;transition:background .2s ease;cursor:pointer}.vp-livreur-item:hover{background:var(--bg-secondary)}.vp-livreur-content{min-width:0}.vp-livreur-content .vp-livreur-name{display:block;font-size:.85rem}.vp-livreur-tournee{font-size:.75rem;color:var(--text-muted)}.vp-livreur-actions{display:flex;gap:.25rem}.vp-action-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:var(--text-muted);text-decoration:none;transition:all .2s ease;cursor:pointer}.vp-action-btn:hover{background:var(--color-primary);color:#fff}.vp-finance-card{background:var(--bg-card)}.vp-finance-grid{padding:1rem 1.25rem}.vp-finance-item{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0}.vp-finance-item.total{border-top:1px solid var(--border-color);margin-top:.75rem;padding-top:.75rem}.vp-finance-label{font-size:.8rem;color:var(--text-muted)}.vp-finance-value{font-size:.9rem;font-weight:600;color:var(--text-primary)}.vp-finance-value.negative{color:#ef4444}.vp-finance-value.positive{color:#22c55e}.vp-finance-item.total .vp-finance-label{font-weight:600;color:var(--text-primary)}.vp-finance-item.total .vp-finance-value{font-size:1.1rem}.vp-finance-bar{position:relative;height:6px;background:var(--bg-secondary);border-radius:10px;margin:0 1.25rem 1rem;overflow:hidden}.vp-finance-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),#22c55e);border-radius:var(--radius-lg);transition:var(--transition-base)}.vp-finance-bar-label{position:absolute;right:0;top:-18px;font-size:.7rem;font-weight:500;color:var(--text-muted)}.vp-delete-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all .2s ease;opacity:0}.vp-tournee-item:hover .vp-delete-btn{opacity:1}.vp-delete-btn:hover{background:#ef44441a;color:#ef4444}.vp-action-btn.danger{opacity:0;background:transparent}.vp-livreur-item:hover .vp-action-btn.danger{opacity:1}.vp-action-btn.danger:hover{background:#ef44441a;color:#ef4444}@media(max-width:1200px){.vp-main-grid{grid-template-columns:1fr}.vp-right-column{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.vp-finance-card{grid-column:span 2}}@media(max-width:900px){.vp-stats-section{grid-template-columns:repeat(2,1fr)}.vp-right-column{grid-template-columns:1fr}.vp-finance-card{grid-column:auto}}@media(max-width:600px){.vp-content{padding:1rem}.vp-header{flex-direction:column;gap:1rem;align-items:flex-start;padding:1rem}.vp-header-actions{width:100%;justify-content:flex-end}.vp-stats-section{grid-template-columns:1fr}.vp-planning-item{grid-template-columns:16px 1fr;gap:.75rem}.vp-planning-livreur,.vp-planning-amount{display:none}.vp-stat-value{font-size:1.25rem}}.vp-tournees-list::-webkit-scrollbar,.vp-livreurs-list::-webkit-scrollbar{width:4px}.vp-tournees-list::-webkit-scrollbar-track,.vp-livreurs-list::-webkit-scrollbar-track{background:transparent}.vp-tournees-list::-webkit-scrollbar-thumb,.vp-livreurs-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:10px}.vp-tournees-list::-webkit-scrollbar-thumb:hover,.vp-livreurs-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.dsv-stats-container{display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-6);background-color:var(--bg-primary);min-height:100%}.dsv-stats-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px;color:var(--text-muted)}.dsv-stats-spinner{width:28px;height:28px;border:2px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:dsv-stats-spin .8s linear infinite}@keyframes dsv-stats-spin{to{transform:rotate(360deg)}}.dsv-stats-spinning{animation:dsv-stats-spin .8s linear infinite}.dsv-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}@media(max-width:1200px){.dsv-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.dsv-stats-grid{grid-template-columns:1fr}}.dsv-stats-card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-6);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);transition:border-color var(--transition-base),background var(--transition-base)}.dsv-stats-card:hover{border-color:var(--border-color-hover);background:var(--bg-surface)}.dsv-stats-card-header{display:flex;align-items:center;gap:8px}.dsv-stats-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);flex-shrink:0}.dsv-stats-icon-blue{background:#3b82f61f;color:#3b82f6}.dsv-stats-icon-green{background:#10b9811f;color:#10b981}.dsv-stats-icon-amber{background:#f59e0b1f;color:#f59e0b}.dsv-stats-icon-red{background:#ef44441f;color:#ef4444}.dsv-stats-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em}.dsv-stats-value{font-size:22px;font-weight:700;color:var(--text-primary);line-height:1}.dsv-stats-progress{width:100%;height:6px;background-color:var(--bg-surface);border-radius:3px;overflow:hidden}.dsv-stats-progress-bar{height:100%;background:linear-gradient(90deg,#d97706,#f59e0b);border-radius:3px;transition:width .4s ease}.dsv-stats-badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;border-radius:4px;width:fit-content}.dsv-stats-badge-neutral{background-color:#64748b14;color:var(--text-secondary)}.dsv-stats-badge-success{background-color:#10b98114;color:var(--color-success)}.dsv-stats-badge-warning{background-color:#f59e0b14;color:var(--color-warning)}.dsv-stats-badge-info{background-color:#3b82f614;color:var(--color-info)}.dsv-stats-badge-alert,.dsv-stats-badge-danger{background-color:#ef444414;color:var(--color-error)}.dsv-stats-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}@media(max-width:1024px){.dsv-stats-row{grid-template-columns:1fr}}.dsv-stats-chart-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm)}.dsv-stats-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dsv-stats-section-title{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text-primary);margin:0}.dsv-stats-refresh-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.dsv-stats-refresh-btn:hover{background:var(--bg-primary);border-color:var(--border-color-hover);color:var(--text-primary)}.dsv-stats-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.dsv-stats-chart-container{width:100%;min-height:160px}.dsv-chart-tooltip{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;padding:8px 12px;box-shadow:var(--shadow-md)}.dsv-chart-tooltip-label{font-size:11px;font-weight:500;color:var(--text-muted);margin:0 0 2px}.dsv-chart-tooltip-value{font-size:14px;font-weight:700;color:var(--text-primary);margin:0}.dsv-stats-chart{display:flex;gap:10px;height:180px}.dsv-stats-chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;width:45px;padding:4px 4px 24px 0}.dsv-stats-chart-y-label{font-size:10px;font-weight:500;color:var(--text-muted)}.dsv-stats-chart-grid{position:relative;flex:1;display:flex;flex-direction:column}.dsv-stats-chart-lines{position:absolute;inset:0 0 28px;pointer-events:none}.dsv-stats-chart-line{position:absolute;left:0;right:0;height:1px;background-color:var(--border-color);opacity:.5}.dsv-stats-chart-bars{display:flex;align-items:flex-end;justify-content:space-between;gap:6px;height:100%;padding-bottom:24px}.dsv-stats-chart-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;min-width:36px}.dsv-stats-chart-bar{position:relative;width:100%;min-height:3px;background:linear-gradient(180deg,#3b82f6,#2563eb);border-radius:4px 4px 0 0;transition:all .2s ease;cursor:pointer}.dsv-stats-chart-bar:hover{background:linear-gradient(180deg,#60a5fa,#3b82f6);transform:scaleY(1.02)}.dsv-stats-chart-bar-today{background:linear-gradient(180deg,#f59e0b,#d97706)}.dsv-stats-chart-bar-today:hover{background:linear-gradient(180deg,#fbbf24,#f59e0b)}.dsv-stats-chart-bar-value{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:10px;font-weight:600;color:var(--text-primary);white-space:nowrap;opacity:0;transition:opacity .15s ease}.dsv-stats-chart-bar:hover .dsv-stats-chart-bar-value{opacity:1}.dsv-stats-chart-bar-label{font-size:10px;font-weight:500;color:var(--text-muted);text-align:center;white-space:nowrap}.dsv-stats-chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;height:180px;color:var(--text-muted)}.dsv-stats-chart-empty p{margin:0;font-size:12px;font-weight:500;color:var(--text-secondary)}.dsv-stats-finalized-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.dsv-stats-finalized-count{padding:2px 8px;background-color:#10b98114;color:var(--color-success);font-size:11px;font-weight:500;border-radius:4px}.dsv-stats-finalized-list{flex:1;overflow-y:auto;max-height:160px;display:flex;flex-direction:column;gap:6px}.dsv-stats-finalized-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg-surface);border-radius:6px;transition:background-color .15s ease}.dsv-stats-finalized-item:hover{background:var(--bg-primary)}.dsv-stats-finalized-icon{flex-shrink:0}.dsv-stats-icon-success{color:var(--color-success)}.dsv-stats-icon-error{color:var(--color-error)}.dsv-stats-finalized-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.dsv-stats-finalized-ref{font-size:11px;font-weight:600;color:var(--color-primary, #2563eb);font-family:SF Mono,Monaco,Roboto Mono,monospace;letter-spacing:0}.dsv-stats-finalized-dest{font-size:10px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dsv-stats-finalized-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.dsv-stats-finalized-time{font-size:10px;font-weight:500;color:var(--text-muted)}.dsv-stats-badge-mini{padding:1px 5px;font-size:9px;font-weight:500;border-radius:3px}.dsv-stats-badge-mini-success{background-color:#10b98114;color:var(--color-success)}.dsv-stats-badge-mini-danger{background-color:#ef444414;color:var(--color-error)}.dsv-stats-finalized-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--text-muted);padding:20px}.dsv-stats-finalized-empty p{margin:0;font-size:12px;color:var(--text-secondary)}.dsv-stats-urgent-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm)}.dsv-stats-urgent-count{padding:2px 8px;background-color:#ef444414;color:var(--color-error);font-size:11px;font-weight:500;border-radius:4px}.dsv-stats-urgent-list{max-height:280px;overflow-y:auto;margin-top:10px}.dsv-stats-urgent-table{width:100%;border-collapse:collapse}.dsv-stats-urgent-table thead{position:sticky;top:0;background:var(--bg-card);z-index:1}.dsv-stats-urgent-table thead tr{border-bottom:1px solid var(--border-color)}.dsv-stats-urgent-table th{padding:8px 10px;text-align:left;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em}.dsv-stats-urgent-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color .15s ease}.dsv-stats-urgent-table tbody tr:hover{background-color:var(--bg-surface)}.dsv-stats-urgent-table tbody tr:last-child{border-bottom:none}.dsv-stats-urgent-table td{padding:8px 10px;font-size:12px;color:var(--text-secondary)}.dsv-stats-urgent-ref{font-weight:600;color:var(--color-primary, #2563eb);font-family:SF Mono,Monaco,Roboto Mono,monospace;font-size:11px;letter-spacing:0}.dsv-stats-urgent-client{color:var(--text-secondary);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dsv-stats-urgent-destination{color:var(--text-muted)}.dsv-stats-urgent-livreur{color:var(--text-secondary)}.dsv-stats-no-livreur{color:var(--color-warning);font-style:italic;font-size:11px}.dsv-stats-urgent-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;color:var(--text-muted)}.dsv-stats-urgent-empty p{margin:0;font-size:13px;font-weight:500;color:var(--text-secondary)}.dsv-stats-urgent-empty span{font-size:11px;color:var(--text-muted)}.dsv-stats-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 0 0;border-top:1px solid var(--border-color);margin-top:4px}.dsv-stats-last-update{font-size:10px;color:var(--text-muted)}.dsv-stats-updating{font-size:10px;color:var(--color-primary);font-weight:500}@media(max-width:768px){.dsv-stats-container{padding:10px;gap:10px}.dsv-stats-chart-section,.dsv-stats-urgent-section{padding:10px}.dsv-stats-chart{height:160px}.dsv-stats-chart-bars{padding-bottom:22px;gap:4px}.dsv-stats-chart-bar-wrapper{min-width:28px}.dsv-stats-urgent-table th,.dsv-stats-urgent-table td{padding:6px 8px;font-size:11px}.dsv-stats-urgent-table th:nth-child(3),.dsv-stats-urgent-table td:nth-child(3),.dsv-stats-urgent-table th:nth-child(4),.dsv-stats-urgent-table td:nth-child(4){display:none}}@media(max-width:480px){.dsv-stats-value{font-size:20px}.dsv-stats-chart-y-axis{width:40px}.dsv-stats-chart-bar-wrapper{min-width:24px}.dsv-stats-chart-bar-label{font-size:9px}}.dsv-stats-chart-bar:focus-visible,.dsv-stats-card:focus-visible,.dsv-stats-refresh-btn:focus-visible{outline:2px solid #2563eb;outline-offset:2px}@media(prefers-reduced-motion:reduce){.dsv-stats-card,.dsv-stats-chart-bar,.dsv-stats-spinner,.dsv-stats-spinning,.dsv-stats-progress-bar{transition:none;animation:none}}.dsv-stats-urgent-overdue{background-color:#ef444414}.dsv-stats-urgent-date{white-space:nowrap}.dsv-stats-date-overdue{color:var(--color-danger, #ef4444);font-weight:600}.dsv-stats-overdue-badge{display:inline-block;margin-left:4px;padding:1px 5px;font-size:9px;font-weight:600;text-transform:uppercase;background-color:var(--color-danger, #ef4444);color:#fff;border-radius:3px}.dsv-course-modal-overlay{position:fixed;inset:0;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:1rem}.dsv-course-modal{background:var(--bg-primary);border-radius:16px;width:100%;max-width:700px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;border:1px solid var(--border-color)}.dsv-course-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.dsv-course-modal-header-left{display:flex;align-items:center;gap:1rem}.dsv-course-modal-type{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:8px;font-size:.813rem;font-weight:600}.dsv-course-modal-type[data-type=livraison]{background:#3b82f61a;color:#3b82f6}.dsv-course-modal-type[data-type=enlevement]{background:#a855f71a;color:#a855f7}.dsv-course-modal-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.dsv-course-modal-num-interne{font-size:.875rem;font-weight:400;color:var(--text-secondary);margin-left:.5rem}.dsv-course-modal-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s}.dsv-course-modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.dsv-course-modal-statut-bar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:1rem}.dsv-course-modal-statut-current{display:flex;align-items:center;gap:.75rem}.dsv-course-modal-statut-label{font-size:.875rem;color:var(--text-secondary)}.dsv-course-modal-statut-dropdown{position:relative}.dsv-course-modal-statut-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;border:1px solid;transition:all .2s}.dsv-course-modal-statut-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.dsv-course-modal-statut-options{position:absolute;top:calc(100% + 4px);left:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #00000026;min-width:200px;z-index:var(--z-dropdown);overflow:hidden}.dsv-course-modal-statut-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;border:none;background:transparent;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .15s;text-align:left}.dsv-course-modal-statut-option:hover{background:var(--hover-bg, rgba(0, 0, 0, .05));color:var(--hover-color, var(--text-primary))}.dsv-course-modal-statut-option.active{background:var(--bg-secondary);font-weight:600}.dsv-course-modal-statut-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dsv-course-modal-ot-status{display:flex;align-items:center}.dsv-course-modal-ot-linked{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#22c55e1a;color:#22c55e;border-radius:8px;font-size:.875rem;font-weight:500}.dsv-course-modal-ot-unlink{background:transparent;border:none;color:inherit;cursor:pointer;padding:.25rem;border-radius:4px;margin-left:.25rem;opacity:.7;transition:all .2s}.dsv-course-modal-ot-unlink:hover{opacity:1;background:#ef444433;color:#ef4444}.dsv-course-modal-ot-missing{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#f973161a;color:#f97316;border-radius:8px;font-size:.875rem}.dsv-course-modal-ot-link{display:flex;align-items:center;gap:.25rem;background:#f97316;color:#fff;border:none;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;margin-left:.5rem;transition:all .2s}.dsv-course-modal-ot-link:hover{background:#ea580c}.dsv-course-modal-tabs{display:flex;border-bottom:1px solid var(--border-color);padding:0 1.5rem;gap:.5rem}.dsv-course-modal-tab{display:flex;align-items:center;gap:.5rem;padding:1rem 1.25rem;background:transparent;border:none;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s}.dsv-course-modal-tab:hover{color:var(--text-primary)}.dsv-course-modal-tab.active{color:var(--accent-color);border-bottom-color:var(--accent-color)}.dsv-course-modal-tab-badge{background:var(--accent-color);color:#fff;font-size:.688rem;font-weight:600;padding:.125rem .375rem;border-radius:10px;min-width:18px;text-align:center}.dsv-course-modal-content{flex:1;overflow-y:auto;padding:1.5rem}.dsv-course-modal-section{margin-bottom:1.5rem}.dsv-course-modal-section:last-child{margin-bottom:0}.dsv-course-modal-section-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.dsv-course-modal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.dsv-course-modal-field{display:flex;flex-direction:column;gap:.25rem}.dsv-course-modal-field-full{grid-column:1 / -1}.dsv-course-modal-field-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.dsv-course-modal-field-value{display:flex;align-items:center;gap:.5rem;font-size:.938rem;color:var(--text-primary)}.dsv-course-modal-field-value svg{color:var(--text-secondary);flex-shrink:0}.dsv-course-modal-link{display:flex;align-items:center;gap:.375rem;color:var(--accent-color);text-decoration:none;transition:all .2s}.dsv-course-modal-link:hover{text-decoration:underline}.dsv-course-modal-address{background:var(--bg-secondary);padding:1rem;border-radius:8px;border:1px solid var(--border-color)}.dsv-course-modal-address-line{margin:0 0 .25rem;font-size:.938rem;color:var(--text-primary)}.dsv-course-modal-address-city{margin:0;font-size:.875rem;color:var(--text-secondary);font-weight:500}.dsv-course-modal-instructions{background:var(--bg-secondary);padding:1rem;border-radius:8px;border:1px solid var(--border-color);margin:0;font-size:.875rem;color:var(--text-primary);line-height:1.6;white-space:pre-wrap}.dsv-course-modal-livreur{display:flex;align-items:center;gap:1rem;background:var(--bg-secondary);padding:1rem;border-radius:8px;border:1px solid var(--border-color)}.dsv-course-modal-livreur-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent-color),#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600;flex-shrink:0}.dsv-course-modal-livreur-info{flex:1}.dsv-course-modal-livreur-name{display:block;font-size:1rem;font-weight:600;color:var(--text-primary)}.dsv-course-modal-livreur-phone{display:flex;align-items:center;gap:.25rem;font-size:.813rem;color:var(--accent-color);text-decoration:none;margin-top:.25rem}.dsv-course-modal-livreur-phone:hover{text-decoration:underline}.dsv-course-modal-livreur-change{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);padding:.5rem 1rem;border-radius:6px;font-size:.813rem;font-weight:500;cursor:pointer;transition:all .2s}.dsv-course-modal-livreur-change:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--accent-color)}.dsv-course-modal-livreur-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;background:var(--bg-secondary);border-radius:8px;border:1px dashed var(--border-color);color:var(--text-secondary)}.dsv-course-modal-livreur-assign{background:var(--accent-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.dsv-course-modal-livreur-assign:hover{opacity:.9;transform:translateY(-1px)}.dsv-course-modal-timestamps{display:flex;gap:2rem;padding-top:1rem;border-top:1px solid var(--border-color)}.dsv-course-modal-timestamp{display:flex;flex-direction:column;gap:.25rem}.dsv-course-modal-timestamp-label{font-size:.75rem;color:var(--text-muted)}.dsv-course-modal-timestamp-value{font-size:.938rem;font-weight:500;color:var(--text-primary)}.dsv-course-modal-photos{display:flex;flex-direction:column;gap:1.5rem}.dsv-course-modal-upload-zone{padding:1rem;background:var(--bg-secondary);border-radius:12px;border:2px dashed var(--border-color);text-align:center}.dsv-course-modal-upload-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1rem;background:var(--accent-color);color:#fff;border:none;border-radius:8px;font-size:.938rem;font-weight:600;cursor:pointer;transition:all .2s}.dsv-course-modal-upload-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.dsv-course-modal-upload-btn:disabled{opacity:.6;cursor:not-allowed}.dsv-course-modal-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.dsv-course-modal-photo-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;background:var(--bg-secondary);border:1px solid var(--border-color)}.dsv-course-modal-photo-img{width:100%;height:100%;object-fit:cover}.dsv-course-modal-photo-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);display:flex;flex-direction:column;justify-content:flex-end;padding:.75rem;opacity:0;transition:opacity .2s}.dsv-course-modal-photo-item:hover .dsv-course-modal-photo-overlay{opacity:1}.dsv-course-modal-photo-type{font-size:.75rem;font-weight:600;color:#fff;text-transform:uppercase;margin-bottom:.5rem}.dsv-course-modal-photo-actions{display:flex;gap:.5rem}.dsv-course-modal-photo-action{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#fff3;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s;text-decoration:none}.dsv-course-modal-photo-action:hover{background:#ffffff4d}.dsv-course-modal-photo-delete:hover{background:#ef4444cc}.dsv-course-modal-photos-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem;background:var(--bg-secondary);border-radius:12px;color:var(--text-secondary);text-align:center}.dsv-course-modal-photos-empty p{margin:0}.dsv-course-modal-photos-hint{font-size:.813rem;color:var(--text-muted)}.dsv-course-modal-select-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:16px}.dsv-course-modal-select{background:var(--bg-primary);border-radius:12px;width:90%;max-width:400px;max-height:70%;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 40px #0003}.dsv-course-modal-select-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color)}.dsv-course-modal-select-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.dsv-course-modal-select-header button{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:4px}.dsv-course-modal-select-header button:hover{color:var(--text-primary);background:var(--bg-secondary)}.dsv-course-modal-select-content{flex:1;overflow-y:auto;padding:.5rem}.dsv-course-modal-select-loading,.dsv-course-modal-select-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;color:var(--text-secondary)}.dsv-course-modal-select-list{display:flex;flex-direction:column;gap:.25rem}.dsv-course-modal-select-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .15s;text-align:left;color:var(--text-primary)}.dsv-course-modal-select-item:hover{background:var(--bg-secondary)}.dsv-course-modal-select-item.active{background:#3b82f61a;color:var(--accent-color)}.dsv-course-modal-select-item-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent-color),#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.813rem;font-weight:600;flex-shrink:0}.dsv-course-modal-select-item-info{flex:1;display:flex;flex-direction:column;gap:.125rem}.dsv-course-modal-select-item-numero,.dsv-course-modal-select-item-name{font-size:.875rem;font-weight:600}.dsv-course-modal-select-item-date,.dsv-course-modal-select-item-phone{font-size:.75rem;color:var(--text-secondary)}.dsv-course-modal-select-item-montant{font-size:.875rem;font-weight:600;color:#22c55e}@media(max-width:640px){.dsv-course-modal{max-height:95vh;border-radius:12px 12px 0 0;margin-top:auto}.dsv-course-modal-header{padding:1rem}.dsv-course-modal-statut-bar{flex-direction:column;align-items:flex-start}.dsv-course-modal-grid{grid-template-columns:1fr}.dsv-course-modal-timestamps{flex-direction:column;gap:.75rem}.dsv-course-modal-photos-grid{grid-template-columns:repeat(2,1fr)}}.dsv-course-modal-header-actions{display:flex;align-items:center;gap:.75rem}.dsv-course-modal-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.dsv-course-modal-btn-edit{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.dsv-course-modal-btn-edit:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.dsv-course-modal-btn-cancel{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.dsv-course-modal-btn-cancel:hover{background:var(--bg-secondary);color:var(--text-primary)}.dsv-course-modal-btn-save{background:#22c55e;color:#fff}.dsv-course-modal-btn-save:hover{background:#16a34a}.dsv-course-modal-btn-save:disabled,.dsv-course-modal-btn-cancel:disabled{opacity:.6;cursor:not-allowed}.dsv-course-modal-input{width:100%;padding:.625rem .875rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;color:var(--text-primary);transition:all .2s}.dsv-course-modal-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}.dsv-course-modal-input::placeholder{color:var(--text-muted)}.dsv-course-modal-input-full{width:100%}.dsv-course-modal-input-small{width:120px;flex-shrink:0}.dsv-course-modal-edit-address{display:flex;flex-direction:column;gap:.75rem}.dsv-course-modal-edit-row{display:flex;gap:.75rem}.dsv-course-modal-textarea{width:100%;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;color:var(--text-primary);resize:vertical;min-height:80px;font-family:inherit;transition:all .2s}.dsv-course-modal-textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}.dsv-course-modal-textarea::placeholder{color:var(--text-muted)}@media(max-width:640px){.dsv-course-modal-header-actions{gap:.5rem}.dsv-course-modal-btn{padding:.375rem .75rem;font-size:.813rem}.dsv-course-modal-edit-row{flex-direction:column}.dsv-course-modal-input-small{width:100%}}.dsv-course-modal-fiche{height:100%;display:flex;flex-direction:column}.dsv-course-modal-fiche-container{display:flex;flex-direction:column;height:100%}.dsv-course-modal-fiche-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:1rem;border-bottom:1px solid var(--border-color);margin-bottom:1rem}.dsv-course-modal-fiche-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.dsv-course-modal-fiche-download{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--accent-color);color:#fff;border-radius:8px;text-decoration:none;font-size:.875rem;font-weight:500;transition:all .2s}.dsv-course-modal-fiche-download:hover{background:var(--accent-hover);transform:translateY(-1px)}.dsv-course-modal-fiche-viewer{flex:1;min-height:400px;background:var(--bg-secondary);border-radius:12px;overflow:hidden;border:1px solid var(--border-color)}.dsv-course-modal-fiche-pdf{width:100%;height:100%;min-height:400px;border:none}.dsv-course-modal-fiche-img{width:100%;height:auto;max-height:500px;object-fit:contain;background:var(--bg-tertiary)}.dsv-course-modal-fiche-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:4rem 2rem;background:var(--bg-secondary);border-radius:12px;border:1px dashed var(--border-color);color:var(--text-secondary);text-align:center}.dsv-course-modal-fiche-empty p{margin:0}.dsv-course-modal-fiche-hint{font-size:.813rem;color:var(--text-muted)}.dsv-course-modal-date-report{background:var(--bg-card);border-radius:16px;width:100%;max-width:420px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 40px #0003}.dsv-course-modal-date-report-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.dsv-course-modal-date-report-text{margin:0;font-size:.938rem;color:var(--text-secondary);line-height:1.5}.dsv-course-modal-date-report-input-wrapper{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;transition:all .2s}.dsv-course-modal-date-report-input-wrapper:focus-within{border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}.dsv-course-modal-date-report-input-wrapper svg{color:var(--accent-color);flex-shrink:0}.dsv-course-modal-date-report-input{flex:1;background:transparent;border:none;outline:none;font-size:1rem;font-weight:500;color:var(--text-primary);font-family:inherit;cursor:pointer}.dsv-course-modal-date-report-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity .2s}.dsv-course-modal-date-report-input::-webkit-calendar-picker-indicator:hover{opacity:1}[data-theme=dark] .dsv-course-modal-date-report-input::-webkit-calendar-picker-indicator{filter:invert(1)}.dsv-course-modal-date-report-preview{margin:0;padding:.875rem 1rem;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:10px;font-size:.875rem;color:var(--text-secondary);text-align:center}.dsv-course-modal-date-report-preview strong{color:var(--accent-color);font-weight:600}.dsv-course-modal-date-report-actions{display:flex;gap:.75rem;padding-top:.5rem}.dsv-course-modal-date-report-actions .dsv-course-modal-btn{flex:1;justify-content:center;padding:.75rem 1rem}.dsv-course-modal-btn-confirm{background:#f59e0b;color:#fff}.dsv-course-modal-btn-confirm:hover:not(:disabled){background:#d97706}.dsv-course-modal-btn-confirm:disabled{opacity:.6;cursor:not-allowed}.dsv-course-modal-date-report-info{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:8px;font-size:.813rem;font-weight:500;color:#d97706;margin-left:.75rem}.dsv-course-modal-date-report-info svg{flex-shrink:0}.dsv-courses-table-container{display:flex;flex-direction:column;gap:24px;width:100%}.dsv-courses-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-6);padding:var(--space-6);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.dsv-courses-stat-item{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);background:var(--bg-surface);border-radius:var(--radius-lg);transition:background var(--transition-base);position:relative;overflow:hidden}.dsv-courses-stat-item:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:currentColor;opacity:0;transition:opacity .2s ease}.dsv-courses-stat-item:hover{background:var(--bg-primary)}.dsv-courses-stat-item:hover:before{opacity:.3}.dsv-courses-stat-label{font-size:.688rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.dsv-courses-stat-value{font-size:1.75rem;font-weight:700;font-family:var(--font-heading);color:var(--text-primary);line-height:1.2}.dsv-courses-stat-success{color:var(--color-success)}.dsv-courses-stat-warning{color:var(--color-warning)}.dsv-courses-stat-muted{color:var(--text-secondary)}.dsv-courses-stat-error{color:var(--color-error)}.dsv-courses-stat-alert{color:var(--color-warning)}.dsv-courses-stat-divider{display:none}.dsv-courses-filters{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-6);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);flex-wrap:wrap}.dsv-courses-search{position:relative;flex:1;min-width:280px}.dsv-courses-search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;transition:color var(--transition-fast)}.dsv-courses-search-input{width:100%;padding:.625rem var(--spacing-md) .625rem 2.5rem;font-size:.875rem;font-family:var(--font-body);color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);outline:none;transition:all var(--transition-base)}.dsv-courses-search-input::placeholder{color:var(--text-muted)}.dsv-courses-search-input:focus{background:var(--bg-secondary);border-color:var(--color-info);box-shadow:0 0 0 3px #3b82f61f}.dsv-courses-search-input:focus+.dsv-courses-search-icon{color:var(--color-info)}.dsv-courses-filter{position:relative;display:flex;align-items:center;gap:var(--spacing-sm)}.dsv-courses-filter-icon{color:var(--text-muted);flex-shrink:0}.dsv-courses-filter-select{padding:.625rem var(--spacing-md);padding-right:2.25rem;font-size:.875rem;font-weight:500;font-family:var(--font-body);color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);outline:none;cursor:pointer;transition:all var(--transition-base);min-width:160px;appearance:none}.dsv-courses-filter-select:hover{background:var(--bg-surface-hover);border-color:var(--border-color-hover)}.dsv-courses-filter-select:focus{background:var(--bg-secondary);border-color:var(--color-info);box-shadow:0 0 0 3px #3b82f61f}.dsv-courses-filter-chevron{position:absolute;right:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.dsv-courses-new-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:.625rem var(--spacing-lg);font-size:.875rem;font-weight:600;font-family:var(--font-heading);color:#fff;background:var(--color-info);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;margin-left:auto}.dsv-courses-new-btn:hover{background:#2563eb;transform:translateY(-2px);box-shadow:var(--shadow-md)}.dsv-courses-new-btn:active{transform:translateY(0)}.dsv-courses-table-wrapper{overflow-x:auto;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.dsv-courses-table{width:100%;border-collapse:separate;border-spacing:0}.dsv-courses-table thead{background:var(--bg-surface);position:sticky;top:0;z-index:var(--z-base)}.dsv-courses-table th{padding:var(--spacing-lg) var(--spacing-md);text-align:left;font-size:.688rem;font-weight:700;font-family:var(--font-heading);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;border-bottom:2px solid var(--border-color);white-space:nowrap}.dsv-courses-table tbody tr{transition:all var(--transition-base);border-bottom:1px solid var(--border-color)}.dsv-courses-table tbody tr:hover{background:var(--bg-surface);cursor:pointer}.dsv-courses-table tbody tr:active{background:var(--bg-surface-hover)}.dsv-courses-table td{padding:var(--spacing-lg) var(--spacing-md);font-size:.875rem;color:var(--text-secondary);vertical-align:middle}.dsv-courses-table tbody tr:last-child{border-bottom:none}.dsv-courses-rc{display:flex;flex-direction:column;gap:6px}.dsv-courses-rc-number{font-family:SF Mono,Monaco,Roboto Mono,Courier New,monospace;font-size:.875rem;font-weight:600;color:var(--color-primary, #2563eb);letter-spacing:0;line-height:1.2}.dsv-courses-rc-interne{font-size:.75rem;color:var(--text-muted);font-weight:400;font-family:SF Mono,Monaco,Roboto Mono,monospace}.dsv-courses-photos-indicator{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;background:#3b82f614;color:var(--color-info);border-radius:4px;font-size:.688rem;font-weight:500;margin-top:2px}.dsv-courses-type-badge{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:4px 10px;font-size:.75rem;font-weight:500;border-radius:6px;white-space:nowrap;transition:background .2s ease;vertical-align:middle;border:1px solid transparent}.dsv-courses-type-badge[data-type=livraison]{background:#3b82f61f;color:#2563eb;border-color:#3b82f633}.dsv-courses-type-badge[data-type=livraison]:hover{background:#3b82f62e}.dsv-courses-type-badge[data-type=enlevement]{background:#a855f71f;color:#9333ea;border-color:#a855f733}.dsv-courses-type-badge[data-type=enlevement]:hover{background:#a855f72e}.dsv-courses-adresse{display:flex;flex-direction:column;gap:.25rem;max-width:300px}.dsv-courses-adresse-nom{font-size:.875rem;font-weight:600;color:var(--text-primary);line-height:1.3}.dsv-courses-adresse-text{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.813rem;color:var(--text-secondary);line-height:1.4}.dsv-courses-adresse-text svg{color:var(--text-muted);flex-shrink:0}.dsv-courses-adresse-ville{font-size:.75rem;color:var(--text-muted);font-weight:600}.dsv-courses-creneau{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.813rem;font-weight:600;color:var(--text-secondary);white-space:nowrap;font-family:var(--font-heading)}.dsv-courses-creneau svg{color:var(--text-muted);flex-shrink:0}.dsv-courses-ot-linked{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:4px 10px;background:#22c55e1f;color:#16a34a;border-radius:6px;font-size:.75rem;font-weight:500;transition:background .2s ease;vertical-align:middle;border:1px solid rgba(34,197,94,.2)}.dsv-courses-ot-linked:hover{background:#22c55e2e}.dsv-courses-ot-numero{font-family:SF Mono,Monaco,Roboto Mono,monospace;font-size:.75rem;font-weight:600;letter-spacing:0;color:var(--color-primary, #2563eb)}.dsv-courses-ot-missing{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:4px 10px;background:#f973161f;color:#ea580c;border-radius:6px;font-size:.75rem;font-weight:500;vertical-align:middle;border:1px solid rgba(249,115,22,.2)}.dsv-courses-ot-missing:hover{background:#f973162e}.dsv-courses-row-no-ot{background:#f9731604}.dsv-courses-row-no-ot:hover{background:#f973160a}.dsv-courses-statut-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;font-size:.75rem;font-weight:500;border-radius:6px;white-space:nowrap;transition:background .2s ease;vertical-align:middle;border:1px solid transparent}.dsv-courses-livreur-empty,.dsv-courses-livreur-assigned{display:flex;align-items:center;gap:10px}.dsv-courses-avatar-empty{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-surface);border:1px dashed var(--border-color);border-radius:50%;color:var(--text-muted)}.dsv-courses-avatar{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;background:linear-gradient(135deg,#3b82f6,#9333ea);border-radius:50%}.dsv-courses-livreur-text{font-size:14px;font-weight:500;color:var(--text-secondary)}.dsv-courses-livreur-empty .dsv-courses-livreur-text{color:var(--text-muted);font-style:italic}.dsv-courses-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.dsv-courses-action-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.dsv-courses-action-btn:hover{background:var(--bg-surface-hover);border-color:var(--border-color-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.dsv-courses-action-btn:active{transform:translateY(0)}.dsv-courses-action-view{color:var(--color-info)}.dsv-courses-action-view:hover{background:#3b82f61f;border-color:var(--color-info);color:var(--color-info)}.dsv-courses-action-assign{color:var(--color-success)}.dsv-courses-action-assign:hover{background:#22c55e1f;border-color:var(--color-success)}.dsv-courses-action-link{color:var(--color-warning)}.dsv-courses-action-link:hover{background:#f973161f;border-color:var(--color-warning)}.dsv-courses-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-6);padding:5rem var(--space-6);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm)}.dsv-courses-spinner{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--color-info);border-radius:50%;animation:dsv-courses-spin .8s linear infinite}@keyframes dsv-courses-spin{to{transform:rotate(360deg)}}.dsv-courses-loading p{font-size:.875rem;font-weight:500;font-family:var(--font-body);color:var(--text-secondary);margin:0}.dsv-courses-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:5rem var(--space-6);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);color:var(--text-muted)}.dsv-courses-empty-title{font-size:1.125rem;font-weight:600;font-family:var(--font-heading);color:var(--text-primary);margin:0}.dsv-courses-empty-text{font-size:.875rem;color:var(--text-secondary);margin:0}@media(max-width:1024px){.dsv-courses-stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-sm)}.dsv-courses-stat-item{padding:var(--spacing-sm) var(--spacing-md)}.dsv-courses-stat-value{font-size:1.5rem}.dsv-courses-filters{gap:var(--spacing-sm)}.dsv-courses-search{flex:1 1 100%;min-width:unset}.dsv-courses-filter-select{min-width:140px}}@media(max-width:768px){.dsv-courses-stats{grid-template-columns:repeat(2,1fr)}.dsv-courses-table th,.dsv-courses-table td{padding:var(--spacing-md);font-size:.813rem}.dsv-courses-adresse{max-width:200px}.dsv-courses-adresse-text{font-size:.75rem}.dsv-courses-action-btn{width:32px;height:32px}}@media(max-width:480px){.dsv-courses-stats{grid-template-columns:1fr}.dsv-courses-filters{padding:var(--spacing-md)}}.dsv-ot-modal-overlay{position:fixed;inset:0;background-color:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--spacing-lg);animation:otModalFadeIn .2s ease}@keyframes otModalFadeIn{0%{opacity:0}to{opacity:1}}.dsv-ot-modal{background:var(--bg-card);border-radius:var(--radius-xl);width:100%;max-width:900px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #0006;border:1px solid var(--border-color);animation:otModalSlideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes otModalSlideUp{0%{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.dsv-ot-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xl);border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,var(--bg-surface) 0%,var(--bg-card) 100%)}.dsv-ot-modal-header-left{display:flex;align-items:center;gap:var(--spacing-lg)}.dsv-ot-modal-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(135deg,var(--color-info) 0%,#2563eb 100%);border-radius:var(--radius-lg);color:#fff;box-shadow:0 4px 12px #3b82f64d}.dsv-ot-modal-header-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.dsv-ot-modal-title{display:flex;align-items:center;gap:var(--spacing-md);font-size:1.5rem;font-weight:700;font-family:var(--font-heading);color:var(--text-primary);margin:0}.dsv-ot-modal-numero{font-family:Monaco,Courier New,monospace;font-size:1.25rem;color:var(--color-info);background:#3b82f61a;padding:.25rem .75rem;border-radius:var(--radius-md)}.dsv-ot-modal-meta{display:flex;align-items:center;gap:var(--spacing-lg)}.dsv-ot-modal-date{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;color:var(--text-secondary)}.dsv-ot-modal-montant{font-size:1rem;font-weight:700;font-family:var(--font-heading);color:var(--color-success);background:#22c55e1a;padding:.25rem .75rem;border-radius:var(--radius-md)}.dsv-ot-modal-header-right{display:flex;align-items:center;gap:var(--spacing-sm)}.dsv-ot-modal-btn-refresh{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.dsv-ot-modal-btn-refresh:hover:not(:disabled){background:var(--bg-surface-hover);color:var(--color-info);border-color:var(--color-info)}.dsv-ot-modal-btn-refresh:disabled{opacity:.6;cursor:not-allowed}.dsv-ot-modal-btn-refresh .spinning{animation:spin 1s linear infinite}.dsv-ot-modal-close{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base)}.dsv-ot-modal-close:hover{background:#ef44441a;color:var(--color-error);border-color:var(--color-error);transform:rotate(90deg)}.dsv-ot-modal-apurement{padding:var(--spacing-lg) var(--spacing-xl);background:var(--bg-surface);border-bottom:1px solid var(--border-color)}.dsv-ot-modal-apurement-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.dsv-ot-modal-apurement-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.938rem;font-weight:600;color:var(--text-primary)}.dsv-ot-modal-apurement-icon-success{color:var(--color-success)}.dsv-ot-modal-apurement-icon-pending{color:var(--color-warning)}.dsv-ot-modal-apurement-stats{display:flex;align-items:center;gap:var(--spacing-md)}.dsv-ot-modal-apurement-count{font-size:.875rem;color:var(--text-secondary)}.dsv-ot-modal-apurement-percent{font-size:1.125rem;font-weight:700;font-family:var(--font-heading);color:var(--text-primary)}.dsv-ot-modal-apurement-bar{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-sm)}.dsv-ot-modal-apurement-progress{height:100%;background:linear-gradient(90deg,var(--color-warning) 0%,var(--color-success) 100%);border-radius:var(--radius-full);transition:width .5s ease}.dsv-ot-modal-apurement-progress.complete{background:var(--color-success)}.dsv-ot-modal-apurement-legend{display:flex;align-items:center;gap:var(--spacing-lg)}.dsv-ot-modal-legend-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--text-secondary)}.dsv-ot-modal-legend-dot{width:8px;height:8px;border-radius:50%}.dsv-ot-modal-legend-success .dsv-ot-modal-legend-dot{background:var(--color-success)}.dsv-ot-modal-legend-pending .dsv-ot-modal-legend-dot{background:var(--color-warning)}.dsv-ot-modal-tabs{display:flex;gap:var(--spacing-xs);padding:0 var(--spacing-xl);background:var(--bg-surface);border-bottom:2px solid var(--border-color)}.dsv-ot-modal-tab{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-xl);background:transparent;border:none;color:var(--text-muted);font-size:.875rem;font-weight:600;font-family:var(--font-heading);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all var(--transition-base)}.dsv-ot-modal-tab:hover{color:var(--text-secondary);background:var(--bg-surface-hover)}.dsv-ot-modal-tab.active{color:var(--color-info);border-bottom-color:var(--color-info)}.dsv-ot-modal-content{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.dsv-ot-modal-section{margin-bottom:var(--spacing-xl)}.dsv-ot-modal-section:last-child{margin-bottom:0}.dsv-ot-modal-section-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.875rem;font-weight:700;font-family:var(--font-heading);color:var(--text-secondary);margin:0 0 var(--spacing-md) 0;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color)}.dsv-ot-modal-section-title svg{color:var(--color-warning)}.dsv-ot-modal-section-success svg{color:var(--color-success)}.dsv-ot-modal-courses-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.dsv-ot-modal-course{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-base)}.dsv-ot-modal-course:hover{border-color:var(--border-color-hover);box-shadow:var(--shadow-sm)}.dsv-ot-modal-course-apure{border-left:3px solid var(--color-success)}.dsv-ot-modal-course-encours{border-left:3px solid var(--color-warning)}.dsv-ot-modal-course-left{display:flex;align-items:center;gap:var(--spacing-md);flex:1;min-width:0}.dsv-ot-modal-course-type{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);flex-shrink:0}.dsv-ot-modal-course-type[data-type=livraison]{background:#3b82f61a;color:var(--color-info)}.dsv-ot-modal-course-type[data-type=enlevement]{background:#a855f71a;color:#a855f7}.dsv-ot-modal-course-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.dsv-ot-modal-course-rc{font-size:.938rem;font-weight:600;font-family:var(--font-heading);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dsv-ot-modal-course-num{font-size:.75rem;font-weight:500;color:var(--text-muted);margin-left:var(--spacing-sm)}.dsv-ot-modal-course-dest{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.813rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dsv-ot-modal-course-dest svg{color:var(--text-muted);flex-shrink:0}.dsv-ot-modal-course-ville{font-size:.75rem;color:var(--text-muted);font-weight:500}.dsv-ot-modal-course-right{display:flex;align-items:center;gap:var(--spacing-md);flex-shrink:0}.dsv-ot-modal-course-rdv{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.75rem;color:var(--text-muted);background:var(--bg-tertiary);padding:.25rem .5rem;border-radius:var(--radius-sm)}.dsv-ot-modal-course-statut{display:flex;align-items:center;gap:var(--spacing-xs);padding:.375rem .75rem;font-size:.75rem;font-weight:600;border-radius:var(--radius-md);white-space:nowrap}.dsv-ot-modal-pdf{height:100%;min-height:500px}.dsv-ot-modal-pdf-container{display:flex;flex-direction:column;height:100%;min-height:500px}.dsv-ot-modal-pdf-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md) var(--radius-md) 0 0;font-size:.875rem;font-weight:600;color:var(--text-secondary)}.dsv-ot-modal-pdf-download{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-info);text-decoration:none;font-weight:600;transition:all var(--transition-fast)}.dsv-ot-modal-pdf-download:hover{text-decoration:underline}.dsv-ot-modal-pdf-viewer{flex:1;width:100%;min-height:450px;border:1px solid var(--border-color);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);background:var(--bg-secondary)}.dsv-ot-modal-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:4rem var(--spacing-xl);color:var(--text-muted);text-align:center}.dsv-ot-modal-empty p{margin:0;font-size:.938rem;font-weight:500}@media(max-width:768px){.dsv-ot-modal-overlay{padding:0}.dsv-ot-modal{max-height:100vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;margin-top:auto}.dsv-ot-modal-header{padding:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.dsv-ot-modal-icon{width:48px;height:48px}.dsv-ot-modal-title{font-size:1.25rem;flex-wrap:wrap}.dsv-ot-modal-numero{font-size:1rem}.dsv-ot-modal-meta{flex-wrap:wrap;gap:var(--spacing-sm)}.dsv-ot-modal-apurement{padding:var(--spacing-md) var(--spacing-lg)}.dsv-ot-modal-tabs{padding:0 var(--spacing-md)}.dsv-ot-modal-tab{padding:var(--spacing-md);font-size:.813rem}.dsv-ot-modal-content{padding:var(--spacing-lg)}.dsv-ot-modal-course{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.dsv-ot-modal-course-right{width:100%;justify-content:space-between}.dsv-ot-modal-pdf-header{flex-direction:column;gap:var(--spacing-sm);text-align:center}}.dsv-ordres-container{display:flex;flex-direction:column;gap:24px}.dsv-ordres-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}.dsv-ordres-stat-card{display:flex;align-items:center;gap:var(--space-4);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-base)}.dsv-ordres-stat-card:hover{border-color:var(--border-color-hover);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.dsv-ordres-stat-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:10px;flex-shrink:0}.dsv-ordres-stat-icon-primary{background-color:#3b82f61a;color:var(--color-primary)}.dsv-ordres-stat-icon-success{background-color:#10b9811a;color:var(--color-success)}.dsv-ordres-stat-icon-warning{background-color:#f59e0b1a;color:var(--color-warning)}.dsv-ordres-stat-icon-info{background-color:#3b82f61a;color:var(--color-info)}.dsv-ordres-stat-content{display:flex;flex-direction:column;gap:4px}.dsv-ordres-stat-label{font-size:13px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.dsv-ordres-stat-value{font-size:24px;font-weight:700;color:var(--text-primary);font-family:var(--font-heading);line-height:1}.dsv-ordres-filters{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-6)}.dsv-ordres-filters-left{display:flex;align-items:center;gap:24px;flex-wrap:wrap}.dsv-ordres-filter-group{display:flex;align-items:center;gap:12px;color:var(--text-muted)}.dsv-ordres-filter-group svg{flex-shrink:0}.dsv-ordres-filter-btn{background:none;border:1px solid var(--border-color);border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap}.dsv-ordres-filter-btn:hover{background-color:var(--bg-surface);border-color:var(--border-color-hover);color:var(--text-primary)}.dsv-ordres-filter-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.dsv-ordres-filter-select{background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:8px;padding:8px 12px;font-size:13px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s ease;outline:none}.dsv-ordres-filter-select:hover{border-color:var(--border-color-hover)}.dsv-ordres-filter-select:focus{border-color:var(--color-primary);box-shadow:var(--shadow-focus-primary)}.dsv-ordres-refresh-btn{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--color-success) 0%,#059669 100%);border:none;border-radius:8px;padding:10px 18px;font-size:13px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 8px #10b98140}.dsv-ordres-refresh-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98159}.dsv-ordres-refresh-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.dsv-ordres-refresh-btn svg.spinning{animation:spin 1s linear infinite}.dsv-ordres-refresh-message{display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:10px;font-size:14px;font-weight:500;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dsv-ordres-refresh-message.success{background-color:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--color-success)}.dsv-ordres-refresh-message.error{background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--color-error)}.dsv-ordres-search{display:flex;align-items:center;gap:10px;background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:8px;padding:10px 14px;color:var(--text-muted);transition:all .2s ease;min-width:280px}.dsv-ordres-search:focus-within{border-color:var(--color-primary);box-shadow:var(--shadow-focus-primary)}.dsv-ordres-search-input{background:none;border:none;outline:none;font-size:13px;font-weight:500;color:var(--text-primary);flex:1;font-family:inherit}.dsv-ordres-search-input::placeholder{color:var(--text-muted)}.dsv-ordres-table-container{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden}.dsv-ordres-table{width:100%;border-collapse:collapse}.dsv-ordres-table thead{background-color:var(--bg-surface);border-bottom:1px solid var(--border-color)}.dsv-ordres-table th{padding:16px 20px;text-align:left;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.dsv-ordres-table-row{border-bottom:1px solid var(--border-color);transition:background-color .2s ease}.dsv-ordres-table-row:hover{background-color:var(--bg-surface)}.dsv-ordres-table-row:last-child{border-bottom:none}.dsv-ordres-table td{padding:16px 20px;font-size:14px;color:var(--text-secondary);vertical-align:middle}.dsv-ordres-table-numero{font-weight:600;color:var(--text-primary)}.dsv-ordres-numero-wrapper{display:flex;align-items:center;gap:10px;color:var(--text-primary)}.dsv-ordres-numero-wrapper svg{color:var(--text-muted)}.dsv-ordres-courses-count,.dsv-ordres-table-montant{font-weight:600;color:var(--text-primary);font-family:var(--font-heading)}.dsv-ordres-badge{display:inline-flex;align-items:center;padding:6px 12px;font-size:12px;font-weight:600;border-radius:6px;white-space:nowrap;border:1px solid transparent;transition:all .2s ease}.dsv-ordres-badge-success{background-color:#22c55e1f;color:#16a34a;border-color:#22c55e33}.dsv-ordres-badge-success:hover{background-color:#22c55e2e}.dsv-ordres-badge-warning{background-color:#f973161f;color:#ea580c;border-color:#f9731633}.dsv-ordres-badge-warning:hover{background-color:#f973162e}.dsv-ordres-badge-error{background-color:#ef44441f;color:#dc2626;border-color:#ef444433}.dsv-ordres-pdf-link{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);transition:all .2s ease;text-decoration:none}.dsv-ordres-pdf-link:hover{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-sm)}.dsv-ordres-no-pdf{display:inline-block;width:32px;text-align:center;color:var(--text-muted);font-size:16px}.dsv-ordres-pdf-loading{display:inline-block;width:32px;text-align:center;color:var(--text-muted);font-size:12px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.dsv-ordres-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:none;border:1px solid var(--border-color);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap;vertical-align:middle}.dsv-ordres-action-btn:hover{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}.dsv-ordres-action-btn:active{transform:translateY(0)}.dsv-ordres-action-btn svg{transition:transform .2s ease;flex-shrink:0}.dsv-ordres-action-btn:hover svg:last-child{transform:translate(2px)}.dsv-ordres-loading{padding:64px 24px;text-align:center;font-size:14px;color:var(--text-muted);font-weight:500}.dsv-ordres-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 24px;color:var(--text-muted)}.dsv-ordres-empty svg{opacity:.3}.dsv-ordres-empty p{font-size:14px;font-weight:500;margin:0}@media(max-width:1200px){.dsv-ordres-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.dsv-ordres-stats{grid-template-columns:1fr}.dsv-ordres-filters,.dsv-ordres-filters-left{flex-direction:column;align-items:stretch}.dsv-ordres-filter-group{flex-wrap:wrap}.dsv-ordres-search{min-width:unset;width:100%}.dsv-ordres-table-container{overflow-x:auto}.dsv-ordres-table{min-width:800px}}@media(max-width:480px){.dsv-ordres-stat-card{padding:16px}.dsv-ordres-stat-icon{width:40px;height:40px}.dsv-ordres-stat-value{font-size:20px}.dsv-ordres-table th,.dsv-ordres-table td{padding:12px 16px}}.facture-preview{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a1a;background:#fff;line-height:1.5}.facture-preview--preview{box-shadow:0 4px 24px #00000026;border-radius:4px;overflow:hidden;max-width:210mm;margin:0 auto}.facture-page{width:210mm;min-height:297mm;padding:0;background:#fff;position:relative;box-sizing:border-box}.facture-header-bar,.facture-footer-bar{height:12px;background:#0f172a;width:100%}.facture-footer-bar{position:absolute;bottom:0;left:0}.facture-header{padding:30px 40px 20px;display:flex;justify-content:space-between;align-items:flex-start}.facture-header-left{display:flex;align-items:flex-start;gap:20px}.facture-logo{width:80px;height:auto;object-fit:contain}.facture-entreprise{font-size:11px;color:#374151}.facture-entreprise-nom{font-size:18px;font-weight:700;color:#0f172a;margin:0 0 8px;border-bottom:2px solid #0f172a;padding-bottom:4px;display:inline-block}.facture-entreprise p{margin:2px 0}.facture-info-section{padding:20px 40px;display:flex;justify-content:space-between;align-items:flex-start}.facture-section-title{font-size:12px;font-weight:700;color:#0f172a;margin:0 0 12px;letter-spacing:.5px}.facture-client{font-size:11px;color:#374151}.facture-client-nom{font-weight:600;color:#0f172a;font-size:13px;margin:0 0 4px}.facture-client p{margin:2px 0}.facture-meta{text-align:right}.facture-meta-row{display:flex;justify-content:flex-end;align-items:baseline;gap:16px;margin-bottom:8px}.facture-meta-label{font-size:12px;font-weight:700;color:#0f172a;letter-spacing:.5px}.facture-meta-value{font-size:14px;font-weight:500;color:#374151;min-width:100px;text-align:right}.facture-separator{border:none;border-top:1px solid #0f172a;margin:0 40px}.facture-table-section{padding:30px 40px}.facture-table{width:100%;border-collapse:collapse}.facture-table thead th{text-align:left;font-size:12px;font-weight:700;color:#0f172a;padding:12px 0;border-bottom:1px solid #e5e7eb;letter-spacing:.5px}.facture-th-qty{width:60px}.facture-th-desc{width:auto}.facture-th-amount{width:120px;text-align:right!important}.facture-table tbody td{padding:16px 0;font-size:13px;color:#374151;vertical-align:top}.facture-td-qty,.facture-td-desc{font-weight:500}.facture-td-amount{text-align:right;font-weight:500}.facture-td-empty{text-align:center;color:#9ca3af;font-style:italic;padding:40px 0}.facture-totals-section{padding:0 40px}.facture-totals{margin-left:auto;width:280px}.facture-total-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.facture-total-label{font-size:13px;color:#374151}.facture-total-value{font-size:13px;font-weight:500;color:#374151}.facture-ttc-section{padding:30px 40px 60px}.facture-ttc{display:flex;justify-content:space-between;align-items:center;padding:30px 0}.facture-ttc-label{font-size:22px;font-weight:700;color:#0f172a;line-height:1.3}.facture-ttc-value{font-size:32px;font-weight:700;color:#0f172a}@media print{.facture-preview{box-shadow:none;border-radius:0}.facture-preview--preview{max-width:none}.facture-page{width:100%;min-height:auto;page-break-after:always}.facture-header-bar,.facture-footer-bar{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background:#0f172a!important}}@media(max-width:900px){.facture-preview--preview{max-width:100%;transform-origin:top left}.facture-page{width:100%;min-height:auto;padding-bottom:40px}.facture-header{padding:20px}.facture-logo{width:60px}.facture-entreprise-nom{font-size:16px}.facture-info-section{padding:16px 20px;flex-direction:column;gap:24px}.facture-meta{text-align:left}.facture-meta-row{justify-content:flex-start}.facture-separator{margin:0 20px}.facture-table-section{padding:20px;overflow-x:auto}.facture-totals-section,.facture-ttc-section{padding-left:20px;padding-right:20px}.facture-totals{width:100%}.facture-ttc-label{font-size:18px}.facture-ttc-value{font-size:24px}}.pod-document{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a1a;background:#fff;line-height:1.5}.pod-document--preview{box-shadow:0 4px 24px #00000026;border-radius:4px;overflow:hidden;max-width:210mm;margin:0 auto}.pod-page{width:210mm;min-height:297mm;padding:30px 40px;background:#fff;box-sizing:border-box}.pod-header{margin-bottom:30px}.pod-title{font-size:28px;font-weight:700;color:#0f172a;margin:0 0 16px}.pod-meta{display:flex;flex-direction:column;gap:4px}.pod-date,.pod-compte{font-size:16px;font-weight:500;color:#374151;margin:0}.pod-ot-section{margin-bottom:24px}.pod-table{width:100%;border-collapse:collapse;margin-bottom:16px}.pod-table thead{background:#f8fafc}.pod-table th{text-align:left;font-size:13px;font-weight:700;color:#0f172a;padding:12px 16px;border:1px solid #e2e8f0;letter-spacing:.5px}.pod-th-ot{width:100px}.pod-th-rc{width:120px}.pod-th-pod{width:auto}.pod-table tbody td{padding:16px;border:1px solid #e2e8f0;vertical-align:top}.pod-row{page-break-inside:avoid}.pod-td-ot{vertical-align:middle}.pod-ot-numero{font-size:14px;font-weight:600;color:#0f172a}.pod-td-rc{vertical-align:middle}.pod-rc-numero{display:block;font-size:14px;font-weight:600;color:#0f172a;margin-bottom:4px}.pod-remarque{display:block;font-size:11px;color:#dc2626;font-weight:500;margin-top:4px}.pod-td-pod{padding:12px}.pod-photos{display:flex;gap:12px;flex-wrap:wrap}.pod-photo-container{flex:1;min-width:200px;max-width:300px}.pod-photo{width:100%;height:auto;border-radius:4px;border:1px solid #e2e8f0;object-fit:contain;max-height:250px}.pod-photo-placeholder{flex:1;min-width:200px;max-width:300px;height:180px;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#94a3b8}.pod-photo-placeholder span{font-size:12px;font-weight:500}.pod-placeholder-icon{opacity:.5}.pod-empty{text-align:center;padding:60px 20px;color:#64748b}.pod-empty p{margin:0;font-size:15px}@media print{.pod-document{box-shadow:none;border-radius:0}.pod-document--preview{max-width:none}.pod-page{width:100%;min-height:auto;padding:20px}.pod-row,.pod-ot-section{page-break-inside:avoid}.pod-photo{max-height:200px}.pod-table th{background:#f8fafc!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}@media(max-width:900px){.pod-document--preview{max-width:100%}.pod-page{width:100%;min-height:auto;padding:20px}.pod-title{font-size:22px}.pod-date,.pod-compte{font-size:14px}.pod-photos{flex-direction:column}.pod-photo-container,.pod-photo-placeholder{max-width:100%}.pod-table th,.pod-table td{padding:10px;font-size:12px}.pod-th-ot{width:80px}.pod-th-rc{width:100px}}.pod-page-break{page-break-after:always}.pod-remarque-important{background:#fef2f2;padding:4px 8px;border-radius:4px;color:#dc2626}.gen-invoice-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:20px}.gen-invoice-modal{background:var(--bg-card);border-radius:16px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:gen-invoice-slide-up .3s ease}@keyframes gen-invoice-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.gen-invoice-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid var(--border-color)}.gen-invoice-header-left{flex:1}.gen-invoice-title{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.gen-invoice-subtitle{margin:4px 0 0;font-size:14px;color:var(--text-muted)}.gen-invoice-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:var(--text-muted);border-radius:8px;cursor:pointer;transition:all .2s ease}.gen-invoice-close:hover{background:var(--bg-hover);color:var(--text-primary)}.gen-invoice-numero-section{padding:16px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.gen-invoice-numero-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.gen-invoice-numero-wrapper{display:flex;align-items:center;gap:12px}.gen-invoice-numero-value{font-size:24px;font-weight:700;color:var(--text-primary)}.gen-invoice-numero-input{font-size:24px;font-weight:700;color:var(--text-primary);background:var(--bg-card);border:2px solid var(--color-primary);border-radius:8px;padding:4px 12px;outline:none;width:200px}.gen-invoice-numero-edit{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-muted);border-radius:6px;cursor:pointer;transition:all .2s ease}.gen-invoice-numero-edit:hover{border-color:var(--color-primary);color:var(--color-primary);background:#3b82f60d}.gen-invoice-error{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:13px;color:#dc2626}.gen-invoice-summary{display:flex;gap:32px;padding:16px 24px;border-bottom:1px solid var(--border-color)}.gen-invoice-summary-item{display:flex;flex-direction:column;gap:4px}.gen-invoice-summary-label{font-size:12px;color:var(--text-muted);font-weight:500}.gen-invoice-summary-value{font-size:18px;font-weight:600;color:var(--text-primary)}.gen-invoice-summary-total .gen-invoice-summary-value{color:var(--color-primary);font-size:20px}.gen-invoice-tabs{display:flex;gap:4px;padding:12px 24px;border-bottom:1px solid var(--border-color)}.gen-invoice-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease}.gen-invoice-tab:hover{background:var(--bg-hover);color:var(--text-secondary)}.gen-invoice-tab--active{background:var(--color-primary);color:#fff}.gen-invoice-tab--active:hover{background:var(--color-primary-hover);color:#fff}.gen-invoice-preview-wrapper{flex:1;overflow:hidden;background:#e5e7eb;min-height:400px}.gen-invoice-preview-scroll{height:100%;max-height:450px;overflow-y:auto;padding:24px}.gen-invoice-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.gen-invoice-footer-left,.gen-invoice-footer-right{display:flex;align-items:center;gap:12px}.gen-invoice-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.gen-invoice-btn--primary{background:var(--color-primary);color:#fff;border:none}.gen-invoice-btn--primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.gen-invoice-btn--primary:disabled{background:#94a3b8;cursor:not-allowed;transform:none;box-shadow:none}.gen-invoice-btn--secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color)}.gen-invoice-btn--secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-muted)}.gen-invoice-btn--cancel{background:transparent;color:var(--text-muted);border:none}.gen-invoice-btn--cancel:hover:not(:disabled){color:var(--text-secondary);background:var(--bg-hover)}.gen-invoice-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:gen-invoice-spin .8s linear infinite}.gen-invoice-btn--secondary .gen-invoice-spinner{border:2px solid rgba(59,130,246,.2);border-top-color:var(--color-primary)}@keyframes gen-invoice-spin{to{transform:rotate(360deg)}}@media(max-width:768px){.gen-invoice-modal{max-height:100vh;border-radius:0}.gen-invoice-header,.gen-invoice-numero-section,.gen-invoice-summary,.gen-invoice-tabs,.gen-invoice-footer{padding-left:16px;padding-right:16px}.gen-invoice-summary{flex-wrap:wrap;gap:16px}.gen-invoice-footer{flex-direction:column;gap:12px}.gen-invoice-footer-left,.gen-invoice-footer-right{width:100%;justify-content:center}.gen-invoice-btn{flex:1;justify-content:center}.gen-invoice-preview-scroll{padding:16px}}.dsv-fact-container{display:flex;flex-direction:column;gap:32px;padding:24px}.dsv-fact-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 24px;color:var(--text-muted)}.dsv-fact-loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:dsv-fact-spin .8s linear infinite}@keyframes dsv-fact-spin{to{transform:rotate(360deg)}}.dsv-fact-tabs{display:flex;gap:8px;padding:4px;background:var(--bg-secondary);border-radius:12px;width:fit-content}.dsv-fact-tab{display:flex;align-items:center;gap:8px;padding:12px 20px;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease}.dsv-fact-tab:hover{color:var(--text-secondary);background:var(--bg-card)}.dsv-fact-tab-active{color:var(--text-primary);background:var(--bg-card);box-shadow:0 1px 3px #00000014}.dsv-fact-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:20px;padding:0 6px;background:var(--bg-surface);color:var(--text-secondary);font-size:12px;font-weight:600;border-radius:10px;transition:all .2s ease}.dsv-fact-tab-active .dsv-fact-tab-count{background:var(--color-primary);color:var(--bg-card)}.dsv-fact-content{flex:1}.dsv-fact-section{display:flex;flex-direction:column;gap:24px}.dsv-fact-section-header{display:flex;flex-direction:column;gap:4px}.dsv-fact-section-header h3{margin:0;color:var(--text-primary);font-size:18px;font-weight:600}.dsv-fact-section-desc{margin:0;color:var(--text-muted);font-size:14px}.dsv-fact-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 24px;color:var(--text-muted);text-align:center}.dsv-fact-empty svg{opacity:.5}.dsv-fact-empty p{margin:0;font-size:15px}.dsv-fact-empty-small{padding:32px 24px;text-align:center;color:var(--text-muted);font-size:14px}.dsv-fact-empty-small p{margin:0}.dsv-fact-table-container{overflow-x:auto;border:1px solid var(--border-color);border-radius:12px;background:var(--bg-card)}.dsv-fact-table{width:100%;border-collapse:collapse}.dsv-fact-table thead{background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.dsv-fact-table th{padding:16px 20px;text-align:left;color:var(--text-secondary);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.dsv-fact-th-checkbox{width:48px;padding-left:20px}.dsv-fact-table td{padding:16px 20px;border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:14px}.dsv-fact-td-checkbox{width:48px;padding-left:20px}.dsv-fact-table tbody tr{transition:background-color .2s ease}.dsv-fact-table tbody tr:hover{background:var(--bg-hover)}.dsv-fact-row-selected{background:#3b82f60d!important}.dsv-fact-checkbox{display:inline-flex;align-items:center;cursor:pointer;position:relative}.dsv-fact-checkbox input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.dsv-fact-checkbox-custom{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:2px solid var(--border-color);border-radius:4px;background:var(--bg-card);transition:all .2s ease}.dsv-fact-checkbox input[type=checkbox]:checked+.dsv-fact-checkbox-custom{background:var(--color-primary);border-color:var(--color-primary)}.dsv-fact-checkbox input[type=checkbox]:checked+.dsv-fact-checkbox-custom:after{content:"";display:block;width:4px;height:8px;border:solid var(--bg-card);border-width:0 2px 2px 0;transform:rotate(45deg);margin-top:-2px}.dsv-fact-checkbox:hover .dsv-fact-checkbox-custom{border-color:var(--text-muted)}.dsv-fact-checkbox input[type=checkbox]:checked:hover+.dsv-fact-checkbox-custom{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.dsv-fact-ordre-num{font-weight:600;color:var(--text-primary)}.dsv-fact-courses-ratio,.dsv-fact-courses-count{color:var(--text-muted);font-size:13px}.dsv-fact-montant{font-weight:600;color:var(--text-primary)}.dsv-fact-progress-container{display:flex;align-items:center;gap:12px}.dsv-fact-progress-bar{flex:1;height:8px;background:var(--bg-surface);border-radius:4px;overflow:hidden}.dsv-fact-progress-fill{height:100%;background:var(--color-primary);border-radius:4px;transition:width .3s ease}.dsv-fact-progress-label{min-width:40px;text-align:right;color:var(--text-muted);font-size:13px;font-weight:500}.dsv-fact-btn-expand{padding:6px 12px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-muted);font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s ease}.dsv-fact-btn-expand:hover{border-color:var(--border-color-hover);background:var(--bg-hover);color:var(--text-secondary)}.dsv-fact-details{padding:20px;background:var(--bg-secondary);border-radius:8px}.dsv-fact-details h4{margin:0 0 16px;color:var(--text-primary);font-size:14px;font-weight:600}.dsv-fact-courses-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.dsv-fact-courses-list li{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px}.dsv-fact-course-ref{font-weight:500;color:var(--text-primary)}.dsv-fact-course-statut{margin-left:auto;padding:4px 10px;background:#fef3c7;color:#92400e;font-size:12px;font-weight:500;border-radius:4px}.dsv-fact-no-data{color:var(--text-muted);font-size:13px;text-align:center}.dsv-fact-footer{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:20px 24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;margin-top:24px}.dsv-fact-summary{display:flex;gap:40px}.dsv-fact-summary-item{display:flex;flex-direction:column;gap:4px}.dsv-fact-summary-label{color:var(--text-muted);font-size:13px;font-weight:500}.dsv-fact-summary-value{color:var(--text-primary);font-size:20px;font-weight:600}.dsv-fact-summary-amount{color:var(--color-primary)}.dsv-fact-btn-primary{display:flex;align-items:center;gap:8px;padding:12px 24px;border:none;background:var(--color-primary);color:#fff;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease}.dsv-fact-btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.dsv-fact-btn-primary:active:not(:disabled){transform:translateY(0)}.dsv-fact-btn-primary:disabled{background:var(--bg-surface);color:var(--text-muted);cursor:not-allowed}.dsv-fact-history{padding:24px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px}.dsv-fact-history-header{margin-bottom:20px}.dsv-fact-history-header h3{margin:0;color:var(--text-primary);font-size:16px;font-weight:600}.dsv-fact-history-list{display:flex;flex-direction:column;gap:12px}.dsv-fact-history-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;transition:all .2s ease}.dsv-fact-history-item:hover{border-color:var(--border-color-hover);box-shadow:0 2px 8px #0000000a}.dsv-fact-history-info{flex:1;display:flex;flex-direction:column;gap:8px}.dsv-fact-history-main{display:flex;align-items:center;gap:12px}.dsv-fact-history-num{font-weight:600;color:var(--text-primary);font-size:15px}.dsv-fact-history-meta{display:flex;align-items:center;gap:16px;color:var(--text-muted);font-size:13px}.dsv-fact-history-montant{font-weight:600;color:var(--text-primary)}.dsv-fact-badge{display:inline-flex;padding:4px 10px;font-size:12px;font-weight:600;border-radius:4px}.dsv-fact-badge-draft{background:#f1f5f9;color:#475569}.dsv-fact-badge-issued{background:#fef3c7;color:#92400e}.dsv-fact-badge-paid{background:#dcfce7;color:#166534}.dsv-fact-badge-cancelled{background:#fef2f2;color:#991b1b}.dsv-fact-btn-download{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-muted);font-size:13px;font-weight:500;text-decoration:none;border-radius:6px;transition:all .2s ease}.dsv-fact-btn-download:hover{border-color:var(--color-primary);background:#3b82f60d;color:var(--color-primary)}@media(max-width:768px){.dsv-fact-container{padding:16px;gap:24px}.dsv-fact-tabs{width:100%}.dsv-fact-tab{flex:1;justify-content:center}.dsv-fact-footer{flex-direction:column;align-items:stretch}.dsv-fact-summary{justify-content:space-around}.dsv-fact-btn-primary{width:100%;justify-content:center}.dsv-fact-table th,.dsv-fact-table td{padding:12px 16px}.dsv-fact-history-item{flex-direction:column;align-items:stretch}.dsv-fact-btn-download{width:100%;justify-content:center}}.dsv-fact-section-header-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.dsv-fact-btn-refresh{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;color:var(--text-secondary);background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.dsv-fact-btn-refresh:hover:not(:disabled){background-color:var(--bg-hover);color:var(--text-primary)}.dsv-fact-btn-refresh:disabled{opacity:.6;cursor:not-allowed}.dsv-fact-spinning{animation:dsv-fact-spin .8s linear infinite}.dsv-fact-history-actions{display:flex;align-items:center;gap:8px}.dsv-fact-btn-send{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--color-primary);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.dsv-fact-btn-send:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.dsv-fact-action-menu-container{position:relative}.dsv-fact-btn-action-menu{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-muted);border-radius:6px;cursor:pointer;transition:all .2s ease}.dsv-fact-btn-action-menu:hover{background:var(--bg-hover);border-color:var(--text-muted);color:var(--text-secondary)}.dsv-fact-action-menu{position:absolute;top:100%;right:0;margin-top:4px;min-width:180px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:var(--z-dropdown);overflow:hidden}.dsv-fact-action-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;text-align:left;cursor:pointer;transition:all .15s ease}.dsv-fact-action-menu button:hover{background:var(--bg-hover);color:var(--text-primary)}.dsv-fact-action-menu button svg{opacity:.7}.dsv-fact-action-danger{color:#dc2626!important}.dsv-fact-action-danger:hover{background:#fef2f2!important;color:#991b1b!important}@media(max-width:768px){.dsv-fact-history-actions{flex-wrap:wrap;gap:6px}.dsv-fact-btn-send{font-size:12px;padding:6px 10px}}.dsv-livreurs-container{width:100%;padding:24px}.dsv-livreurs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.dsv-livreurs-header-left{display:flex;align-items:center;gap:12px}.dsv-livreurs-title{font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.dsv-livreurs-count{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 12px;background:var(--bg-surface);color:var(--text-secondary);font-size:14px;font-weight:600;border-radius:8px}.dsv-livreurs-add-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.dsv-livreurs-add-btn:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.dsv-livreurs-add-btn:active{transform:translateY(0)}.dsv-livreurs-search-wrapper{position:relative;margin-bottom:24px}.dsv-livreurs-search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.dsv-livreurs-search{width:100%;padding:12px 16px 12px 48px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;font-size:14px;color:var(--text-primary);transition:all .2s ease}.dsv-livreurs-search::placeholder{color:var(--text-muted)}.dsv-livreurs-search:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus-primary)}.dsv-livreurs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.dsv-livreurs-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:all .2s ease}.dsv-livreurs-card:hover{border-color:var(--border-color-hover);box-shadow:0 4px 12px #0000000d;transform:translateY(-2px)}.dsv-livreurs-card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.dsv-livreurs-avatar{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px;font-size:16px;font-weight:600;color:#fff}.dsv-livreurs-avatar--blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.dsv-livreurs-avatar--purple{background:linear-gradient(135deg,#a855f7,#9333ea)}.dsv-livreurs-avatar--green{background:linear-gradient(135deg,#10b981,#059669)}.dsv-livreurs-avatar--orange{background:linear-gradient(135deg,#f59e0b,#d97706)}.dsv-livreurs-avatar--pink{background:linear-gradient(135deg,#ec4899,#db2777)}.dsv-livreurs-info{flex:1;min-width:0}.dsv-livreurs-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dsv-livreurs-badge{display:inline-block;padding:4px 10px;font-size:12px;font-weight:500;border-radius:6px}.dsv-livreurs-badge--actif{background:#10b9811a;color:var(--color-success)}.dsv-livreurs-badge--inactif{background:var(--bg-surface);color:var(--text-secondary)}.dsv-livreurs-contact{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.dsv-livreurs-contact-item{display:flex;align-items:center;gap:8px;color:var(--text-muted)}.dsv-livreurs-contact-item svg{flex-shrink:0}.dsv-livreurs-contact-link{font-size:14px;color:var(--text-secondary);text-decoration:none;transition:color .2s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dsv-livreurs-contact-link:hover{color:var(--color-primary)}.dsv-livreurs-stats{margin-bottom:16px}.dsv-livreurs-stat{display:flex;flex-direction:column;gap:4px}.dsv-livreurs-stat-value{font-size:24px;font-weight:600;color:var(--text-primary)}.dsv-livreurs-stat-label{font-size:13px;color:var(--text-muted)}.dsv-livreurs-actions{display:flex;gap:8px}.dsv-livreurs-action-btn{flex:1;display:flex;align-items:center;justify-content:center;padding:10px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-card);cursor:pointer;transition:all .2s ease}.dsv-livreurs-action-btn:hover{transform:translateY(-1px)}.dsv-livreurs-action-btn--primary{color:var(--color-primary)}.dsv-livreurs-action-btn--primary:hover{background:#3b82f60d;border-color:var(--color-primary)}.dsv-livreurs-action-btn--secondary{color:var(--color-success)}.dsv-livreurs-action-btn--secondary:hover{background:#10b9810d;border-color:var(--color-success)}.dsv-livreurs-action-btn--danger{color:var(--text-muted)}.dsv-livreurs-action-btn--danger:hover{background:#ef44440d;border-color:#ef4444;color:#ef4444}.dsv-livreurs-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center}.dsv-livreurs-empty svg{color:var(--border-color-hover);margin-bottom:16px}.dsv-livreurs-empty-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.dsv-livreurs-empty-subtitle{font-size:14px;color:var(--text-muted);margin:0}.dsv-livreurs-loading{display:flex;align-items:center;justify-content:center;padding:64px}.dsv-livreurs-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:dsv-livreurs-spin .8s linear infinite}@keyframes dsv-livreurs-spin{to{transform:rotate(360deg)}}@media(max-width:768px){.dsv-livreurs-container{padding:16px}.dsv-livreurs-header{flex-direction:column;align-items:stretch;gap:16px}.dsv-livreurs-add-btn{justify-content:center}.dsv-livreurs-grid{grid-template-columns:1fr}}.dsv-new-course-overlay{position:fixed;inset:0;background-color:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:1rem;animation:fadeIn .2s ease}.dsv-new-course-modal{background:var(--bg-card);border-radius:16px;width:100%;max-width:700px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;border:1px solid var(--border-color);animation:slideUp .3s ease}.dsv-new-course-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.dsv-new-course-title{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.dsv-new-course-title svg{color:var(--color-primary)}.dsv-new-course-close{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.dsv-new-course-close:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color-hover)}.dsv-new-course-error{margin:1rem 1.5rem 0;padding:.875rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:.875rem;font-weight:500}.dsv-new-course-form{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.dsv-new-course-section{display:flex;flex-direction:column;gap:.75rem}.dsv-new-course-section-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin:0;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.dsv-new-course-section-title svg{color:var(--text-muted)}.dsv-new-course-row{display:flex;gap:1rem}.dsv-new-course-field{display:flex;flex-direction:column;gap:.375rem;flex:1}.dsv-new-course-field-2{flex:2}.dsv-new-course-field-small{flex:0 0 120px}.dsv-new-course-label{display:flex;align-items:center;gap:.375rem;font-size:.813rem;font-weight:500;color:var(--text-secondary)}.dsv-new-course-label svg{color:var(--text-muted)}.dsv-new-course-input,.dsv-new-course-select{width:100%;padding:.625rem .875rem;font-size:.875rem;font-family:inherit;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;outline:none;transition:all .2s}.dsv-new-course-input::placeholder{color:var(--text-muted)}.dsv-new-course-input:focus,.dsv-new-course-select:focus{background:var(--bg-primary);border-color:var(--color-primary);box-shadow:var(--shadow-focus-primary)}.dsv-new-course-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}.dsv-new-course-textarea{width:100%;padding:.75rem;font-size:.875rem;font-family:inherit;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;outline:none;transition:all .2s;resize:vertical;min-height:80px}.dsv-new-course-textarea::placeholder{color:var(--text-muted)}.dsv-new-course-textarea:focus{background:var(--bg-primary);border-color:var(--color-primary);box-shadow:var(--shadow-focus-primary)}.dsv-new-course-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border-color);margin-top:.5rem}.dsv-new-course-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;border:none}.dsv-new-course-btn-cancel{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.dsv-new-course-btn-cancel:hover{background:var(--bg-secondary);color:var(--text-primary)}.dsv-new-course-btn-save{background:var(--color-primary);color:#fff}.dsv-new-course-btn-save:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.dsv-new-course-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media(max-width:640px){.dsv-new-course-modal{max-height:95vh;border-radius:12px 12px 0 0;margin-top:auto}.dsv-new-course-header,.dsv-new-course-form{padding:1rem}.dsv-new-course-row{flex-direction:column}.dsv-new-course-field-small{flex:1}.dsv-new-course-actions{flex-direction:column}.dsv-new-course-btn{width:100%}}.dsv-livreur-modal-overlay{position:fixed;inset:0;background-color:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:1rem;animation:livreurModalFadeIn .2s ease}@keyframes livreurModalFadeIn{0%{opacity:0}to{opacity:1}}.dsv-livreur-modal{background:var(--bg-card);border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;border:1px solid var(--border-color);animation:livreurModalSlideUp .3s ease}@keyframes livreurModalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dsv-livreur-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.dsv-livreur-modal-title{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.dsv-livreur-modal-title svg{color:var(--color-primary)}.dsv-livreur-modal-close{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.dsv-livreur-modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color-hover)}.dsv-livreur-modal-error{margin:1rem 1.5rem 0;padding:.875rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:.875rem;font-weight:500}.dsv-livreur-modal-form{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.dsv-livreur-modal-section{display:flex;flex-direction:column;gap:.75rem}.dsv-livreur-modal-section-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin:0;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.dsv-livreur-modal-section-title svg{color:var(--text-muted)}.dsv-livreur-modal-row{display:flex;gap:1rem}.dsv-livreur-modal-field{display:flex;flex-direction:column;gap:.375rem;flex:1}.dsv-livreur-modal-label{display:flex;align-items:center;gap:.375rem;font-size:.813rem;font-weight:500;color:var(--text-secondary)}.dsv-livreur-modal-label svg{color:var(--text-muted)}.dsv-livreur-modal-input{width:100%;padding:.625rem .875rem;font-size:.875rem;font-family:inherit;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;outline:none;transition:all .2s}.dsv-livreur-modal-input::placeholder{color:var(--text-muted)}.dsv-livreur-modal-input:focus{background:var(--bg-primary);border-color:var(--color-primary);box-shadow:var(--shadow-focus-primary)}.dsv-livreur-modal-toggle-wrapper{display:flex;align-items:center;gap:.75rem}.dsv-livreur-modal-toggle{position:relative;display:inline-block;width:48px;height:26px}.dsv-livreur-modal-toggle-input{opacity:0;width:0;height:0}.dsv-livreur-modal-toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-tertiary);border:1px solid var(--border-color);transition:.3s;border-radius:26px}.dsv-livreur-modal-toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.dsv-livreur-modal-toggle-input:checked+.dsv-livreur-modal-toggle-slider{background-color:#22c55e;border-color:#22c55e}.dsv-livreur-modal-toggle-input:checked+.dsv-livreur-modal-toggle-slider:before{transform:translate(22px)}.dsv-livreur-modal-toggle-label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.dsv-livreur-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border-color);margin-top:.5rem}.dsv-livreur-modal-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;border:none}.dsv-livreur-modal-btn-cancel{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.dsv-livreur-modal-btn-cancel:hover{background:var(--bg-secondary);color:var(--text-primary)}.dsv-livreur-modal-btn-save{background:var(--color-primary);color:#fff}.dsv-livreur-modal-btn-save:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.dsv-livreur-modal-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media(max-width:640px){.dsv-livreur-modal{max-height:95vh;border-radius:12px 12px 0 0;margin-top:auto}.dsv-livreur-modal-header,.dsv-livreur-modal-form{padding:1rem}.dsv-livreur-modal-row,.dsv-livreur-modal-actions{flex-direction:column}.dsv-livreur-modal-btn{width:100%}}.dsv-dashboard{min-height:100vh;background-color:var(--bg-primary);display:flex;flex-direction:column}.dsv-global-error{display:flex;align-items:center;justify-content:space-between;gap:16px;background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:0;padding:12px 24px;color:var(--color-error);font-size:14px;font-weight:500;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dsv-global-error button{background:none;border:none;color:var(--color-error);font-size:20px;cursor:pointer;padding:0;line-height:1;opacity:.7;transition:opacity .2s ease}.dsv-global-error button:hover{opacity:1}.dsv-action-bar{background-color:var(--bg-card);border-bottom:1px solid var(--border-color);padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.dsv-back-button{display:flex;align-items:center;gap:var(--space-2);background:none;border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-2) var(--space-4);cursor:pointer;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-base)}.dsv-back-button:hover{background-color:var(--bg-surface);border-color:var(--border-color-hover);color:var(--text-primary)}.dsv-date-selector{display:flex;align-items:center;gap:var(--space-2);background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-2) var(--space-3);color:var(--text-secondary);transition:border-color var(--transition-base);cursor:pointer}.dsv-date-selector:hover{border-color:var(--border-color-hover)}.dsv-date-selector:has(.dsv-date-input:focus){border-color:var(--color-primary)}.dsv-date-selector svg{color:var(--color-primary)}.dsv-date-input{background:none;border:none;outline:none;font-size:13px;font-weight:500;color:var(--text-primary);font-family:inherit;cursor:pointer;width:130px}.dsv-date-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.5;transition:opacity .2s ease;filter:var(--calendar-icon-filter, none)}[data-theme=dark] .dsv-date-input::-webkit-calendar-picker-indicator{--calendar-icon-filter: invert(1)}.dsv-date-input::-webkit-calendar-picker-indicator:hover{opacity:.8}.dsv-current-date-text{font-size:12px;color:var(--text-muted);white-space:nowrap;text-transform:capitalize}.dsv-new-delivery-button{display:flex;align-items:center;gap:var(--space-2);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-lg);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:background var(--transition-base);box-shadow:var(--shadow-sm)}.dsv-new-delivery-button:hover{background-color:var(--color-primary-hover)}.dsv-new-delivery-button:active{transform:scale(.98)}.dsv-tabs{background-color:var(--bg-card);border-bottom:1px solid var(--border-color);display:flex;position:sticky;top:0;z-index:var(--z-sticky)}.dsv-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 16px;background:none;border:none;border-bottom:2px solid transparent;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:color .2s ease,background .2s ease;position:relative;white-space:nowrap}.dsv-tab:hover{color:var(--text-secondary);background-color:var(--bg-secondary)}.dsv-tab-active{color:var(--color-primary);font-weight:600}.dsv-tab:active{transform:scale(.98)}.dsv-tab-indicator{position:absolute;bottom:0;left:0;height:2px;background-color:var(--color-primary);transition:transform .3s cubic-bezier(.4,0,.2,1)}.dsv-main{flex:1;padding:24px;overflow-y:auto}.dsv-tab-content{animation:dsv-fade-in .3s ease}.dsv-tab-content h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 24px}.dsv-placeholder{font-size:14px;color:var(--text-muted);background-color:var(--bg-card);border:1px dashed var(--border-color);border-radius:8px;padding:48px 24px;text-align:center;margin:0}@keyframes dsv-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dsv-loading-overlay{position:fixed;inset:0;background-color:#0000004d;display:flex;align-items:center;justify-content:center;z-index:var(--z-notification);animation:fadeIn .2s ease}.dsv-loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.dsv-skeleton{background:linear-gradient(90deg,var(--bg-surface) 0%,var(--bg-card) 50%,var(--bg-surface) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:1024px){.dsv-action-bar{padding:12px 16px}.dsv-main{padding:16px}.dsv-tab{font-size:12px;padding:10px 12px}.dsv-tab span,.dsv-current-date-text{display:none}}@media(max-width:768px){.dsv-action-bar{flex-direction:column;align-items:stretch;gap:12px}.dsv-action-bar-right{width:100%;justify-content:space-between}.dsv-new-delivery-button span{display:none}.dsv-main{padding:12px}}@media(max-width:480px){.dsv-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.dsv-tab{flex:0 0 auto;min-width:60px}}.dsv-week-selector{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg);position:relative;cursor:pointer;transition:border-color var(--transition-base)}.dsv-week-selector:hover{border-color:var(--border-color-hover)}.dsv-week-selector:has(.dsv-week-select:focus){border-color:var(--color-primary)}.dsv-week-selector svg:first-child{color:var(--color-primary);flex-shrink:0}.dsv-week-select{appearance:none;background:transparent;border:none;color:var(--text-primary);font-size:13px;font-weight:500;padding-right:24px;cursor:pointer;min-width:140px}.dsv-week-select:focus{outline:none}.dsv-select-chevron{position:absolute;right:10px;color:var(--text-muted);pointer-events:none}.dsv-action-bar-right{display:flex;align-items:center;gap:12px}@media(max-width:768px){.dsv-action-bar-right{flex-direction:column;align-items:stretch;gap:8px}.dsv-week-selector{width:100%}.dsv-week-select{flex:1}}.dsv-action-bar,.dsv-back-button{transition:all var(--transition-base)}.dsv-back-button:hover{transform:translate(-2px);box-shadow:var(--shadow-sm)}.dsv-back-button:active{transform:translate(0) scale(.98)}.dsv-date-selector{transition:all var(--transition-base)}.dsv-date-selector:hover{box-shadow:var(--shadow-sm)}.dsv-date-selector:focus-within{border-color:var(--color-primary);box-shadow:var(--shadow-focus-primary)}.dsv-new-delivery-button{transition:all var(--transition-base)}.dsv-new-delivery-button:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.dsv-tab,.dsv-stats-card,.dsv-stats-badge,.dsv-stats-chart-section,.dsv-stats-refresh-btn{transition:all var(--transition-base)}.dsv-stats-refresh-btn.dsv-stats-spinning{animation:spinRefresh 1s linear infinite}@keyframes spinRefresh{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dsv-courses-stat-item,.dsv-courses-new-btn,.dsv-courses-table tbody tr,.dsv-courses-type-badge,.dsv-courses-photos-indicator,.dsv-courses-ot-linked,.dsv-courses-action-btn{transition:all var(--transition-base)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.dsv-dashboard,.dsv-stats-container,.dsv-courses-table-container,.dsv-action-bar,.dsv-tabs{transition:background-color var(--transition-base),color var(--transition-base),border-color var(--transition-base)}.clients-page{min-height:100vh;background:var(--background-secondary)}.page-content{padding:var(--space-6)}.clients-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.clients-search{position:relative;flex:1;max-width:400px}.clients-search .search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--foreground-muted);pointer-events:none}.clients-search .search-input{width:100%;padding:var(--space-2-5) var(--space-3);padding-left:calc(var(--space-3) + 24px);font-family:var(--font-body);font-size:var(--text-sm);color:var(--foreground);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);outline:none;transition:all var(--transition-fast)}.clients-search .search-input:hover{border-color:var(--border-hover)}.clients-search .search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 var(--ring-offset) var(--background),0 0 0 calc(var(--ring-offset) + var(--ring-width)) var(--ring-color)}.clients-filters{display:flex;gap:var(--space-3);flex-wrap:wrap}.filter-select{padding:var(--space-2-5) var(--space-3);padding-right:var(--space-8);font-family:var(--font-body);font-size:var(--text-sm);color:var(--foreground);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2378716C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-2) center;min-width:160px;transition:all var(--transition-fast)}.filter-select:hover{border-color:var(--border-hover)}.filter-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 var(--ring-offset) var(--background),0 0 0 calc(var(--ring-offset) + var(--ring-width)) var(--ring-color)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2-5) var(--space-4);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);border:none;text-decoration:none}.btn-primary{background:var(--color-primary);color:var(--color-primary-foreground)}.btn-ghost{background:transparent;color:var(--foreground-secondary);border:1px solid var(--border)}.btn-ghost:hover{background:var(--background-tertiary);color:var(--foreground);border-color:var(--border-hover)}.clients-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.client-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-5);cursor:pointer;transition:all var(--transition-normal);animation:slideUp var(--duration-slow) var(--ease-out) backwards}.client-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.client-card:hover .chevron-icon{transform:translate(4px);color:var(--color-primary)}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.client-card-header{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4)}.client-avatar{width:44px;height:44px;background:var(--color-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-weight:var(--font-bold);font-size:var(--text-base);color:var(--color-primary-foreground);flex-shrink:0}.client-info{flex:1;min-width:0}.client-name{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--foreground);margin:0 0 var(--space-1) 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-type{font-size:var(--text-xs);color:var(--foreground-muted)}.status-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0}.status-badge--success{background:var(--color-success-subtle);color:var(--color-success)}.status-badge--warning{background:var(--color-warning-subtle);color:var(--color-warning)}.client-card-details{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4) 0;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-4)}.detail-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--foreground-secondary)}.detail-item svg{color:var(--foreground-muted);flex-shrink:0}.client-card-footer{display:flex;align-items:center;justify-content:space-between}.billing-type{font-size:var(--text-xs);color:var(--foreground-muted);background:var(--background-secondary);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full)}.chevron-icon{color:var(--foreground-muted);transition:all var(--transition-fast)}.empty-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);background:var(--card);border-radius:var(--radius-xl);border:2px dashed var(--border);text-align:center}.empty-state svg{color:var(--foreground-muted);margin-bottom:var(--space-4)}.empty-state p{margin:0 0 var(--space-1) 0;font-weight:var(--font-semibold);color:var(--foreground)}.empty-state span{font-size:var(--text-sm);color:var(--foreground-muted)}@media(max-width:1200px){.clients-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.clients-grid{grid-template-columns:1fr}.clients-toolbar{flex-direction:column;align-items:stretch}.clients-search{max-width:none}.clients-filters{flex-direction:column}.filter-select{width:100%}.page-content,.client-card{padding:var(--space-4)}}[data-theme=dark] .clients-page{background:var(--background)}[data-theme=dark] .client-card{background:var(--card);border-color:var(--card-border)}[data-theme=dark] .filter-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2371717A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.facture-unifiee{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#1a1a1a;background:#fff;line-height:1.5}.facture-unifiee--preview{box-shadow:0 4px 24px #00000026;border-radius:4px;overflow:hidden;max-width:210mm;margin:0 auto}.facture-unifiee-page{width:210mm;min-height:297mm;padding:0;background:#fff;position:relative;box-sizing:border-box}.facture-unifiee-header-bar,.facture-unifiee-footer-bar{height:12px;background:#0f172a;width:100%}.facture-unifiee-footer-bar{position:absolute;bottom:0;left:0}.facture-unifiee-header{padding:30px 40px 20px;display:flex;justify-content:space-between;align-items:flex-start}.facture-unifiee-header-left{display:flex;align-items:flex-start;gap:20px}.facture-unifiee-logo{width:80px;height:auto;object-fit:contain}.facture-unifiee-entreprise{font-size:11px;color:#374151}.facture-unifiee-entreprise-nom{font-size:18px;font-weight:700;color:#0f172a;margin:0 0 8px;border-bottom:2px solid #0f172a;padding-bottom:4px;display:inline-block}.facture-unifiee-entreprise p{margin:2px 0}.facture-unifiee-info-section{padding:20px 40px;display:flex;justify-content:space-between;align-items:flex-start}.facture-unifiee-section-title{font-size:12px;font-weight:700;color:#0f172a;margin:0 0 12px;letter-spacing:.5px}.facture-unifiee-client{font-size:11px;color:#374151}.facture-unifiee-client-nom{font-weight:600;color:#0f172a;font-size:13px;margin:0 0 4px}.facture-unifiee-client p{margin:2px 0}.facture-unifiee-client-empty{color:#9ca3af;font-style:italic}.facture-unifiee-meta{text-align:right}.facture-unifiee-meta-row{display:flex;justify-content:flex-end;align-items:baseline;gap:16px;margin-bottom:8px}.facture-unifiee-meta-label{font-size:12px;font-weight:700;color:#0f172a;letter-spacing:.5px}.facture-unifiee-meta-value{font-size:14px;font-weight:500;color:#374151;min-width:100px;text-align:right}.facture-unifiee-separator{border:none;border-top:1px solid #0f172a;margin:0 40px}.facture-unifiee-table-section{padding:30px 40px}.facture-unifiee-table{width:100%;border-collapse:collapse}.facture-unifiee-table thead th{text-align:left;font-size:12px;font-weight:700;color:#0f172a;padding:12px 0;border-bottom:1px solid #e5e7eb;letter-spacing:.5px}.facture-unifiee-th-qty{width:60px}.facture-unifiee-th-desc{width:auto}.facture-unifiee-th-prix{width:100px;text-align:right!important}.facture-unifiee-th-amount{width:120px;text-align:right!important}.facture-unifiee-table tbody td{padding:16px 0;font-size:13px;color:#374151;vertical-align:top}.facture-unifiee-td-qty,.facture-unifiee-td-desc{font-weight:500}.facture-unifiee-td-prix,.facture-unifiee-td-amount{text-align:right;font-weight:500}.facture-unifiee-td-empty{text-align:center;color:#9ca3af;font-style:italic;padding:40px 0}.facture-unifiee-totals-section{padding:0 40px}.facture-unifiee-totals{margin-left:auto;width:280px}.facture-unifiee-total-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.facture-unifiee-total-label{font-size:13px;color:#374151}.facture-unifiee-total-value{font-size:13px;font-weight:500;color:#374151}.facture-unifiee-ttc-section{padding:30px 40px 60px}.facture-unifiee-ttc{display:flex;justify-content:space-between;align-items:center;padding:30px 0}.facture-unifiee-ttc-label{font-size:22px;font-weight:700;color:#0f172a;line-height:1.3}.facture-unifiee-ttc-value{font-size:32px;font-weight:700;color:#0f172a}@media print{.facture-unifiee{box-shadow:none;border-radius:0}.facture-unifiee--preview{max-width:none}.facture-unifiee-page{width:100%;min-height:auto;page-break-after:always}.facture-unifiee-header-bar,.facture-unifiee-footer-bar{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;background:#0f172a!important}}@media(max-width:900px){.facture-unifiee--preview{max-width:100%;transform-origin:top left}.facture-unifiee-page{width:100%;min-height:auto;padding-bottom:40px}.facture-unifiee-header{padding:20px}.facture-unifiee-logo{width:60px}.facture-unifiee-entreprise-nom{font-size:16px}.facture-unifiee-info-section{padding:16px 20px;flex-direction:column;gap:24px}.facture-unifiee-meta{text-align:left}.facture-unifiee-meta-row{justify-content:flex-start}.facture-unifiee-separator{margin:0 20px}.facture-unifiee-table-section{padding:20px;overflow-x:auto}.facture-unifiee-totals-section,.facture-unifiee-ttc-section{padding-left:20px;padding-right:20px}.facture-unifiee-totals{width:100%}.facture-unifiee-ttc-label{font-size:18px}.facture-unifiee-ttc-value{font-size:24px}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4)}.split-view-modal{background:var(--card);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;display:flex;overflow:hidden;box-shadow:var(--shadow-xl);transition:max-width var(--transition-normal)}.split-view-modal.with-preview{max-width:1100px}.modal-form-panel{flex:1;min-width:0;display:flex;flex-direction:column;max-height:90vh;border-right:1px solid var(--border-subtle)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);background:var(--background)}.modal-header-content{display:flex;align-items:center;gap:var(--space-3)}.modal-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-subtle);color:var(--color-primary);border-radius:var(--radius-lg)}.modal-header-content h2{margin:0;font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--foreground)}.modal-header-content p{margin:0;font-size:var(--text-xs);color:var(--foreground-muted)}.modal-header-actions{display:flex;align-items:center;gap:var(--space-2)}.btn-toggle-preview{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2);background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--foreground-muted);cursor:pointer;transition:all var(--transition-fast)}.btn-toggle-preview:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-subtle)}.modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--foreground-muted);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--background-secondary);color:var(--foreground)}.modal-body{flex:1;overflow-y:auto;padding:var(--space-5)}.form-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--color-error-subtle);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--text-sm);margin-bottom:var(--space-4)}.form-section{margin-bottom:var(--space-5);padding-bottom:var(--space-5);border-bottom:1px solid var(--border-subtle)}.form-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.form-section--compact{padding-bottom:var(--space-3)}.form-section-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--foreground);margin:0 0 var(--space-3) 0}.form-section-title svg{color:var(--foreground-muted)}.form-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.form-section-header .form-section-title{margin:0}.form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-3)}.form-row:last-child{margin-bottom:0}.form-row--stacked{display:flex;flex-direction:column;gap:var(--space-3)}.form-row--stacked .form-row{display:grid;grid-template-columns:repeat(2,1fr)}.form-group{display:flex;flex-direction:column;gap:var(--space-1)}.form-group label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--foreground-muted)}.form-group input,.form-group select,.form-group textarea{padding:var(--space-2) var(--space-3);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--foreground);font-size:var(--text-sm);font-family:var(--font-body);outline:none;transition:all var(--transition-fast)}.form-group input:hover,.form-group select:hover,.form-group textarea:hover{border-color:var(--border-hover)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.form-group input:disabled,.form-group select:disabled{background:var(--background-secondary);color:var(--foreground-muted);cursor:not-allowed}.form-group textarea{resize:vertical;min-height:60px}.client-mode-toggle{display:inline-flex;gap:var(--space-1);margin-bottom:var(--space-3);padding:3px;background:var(--background-secondary);border-radius:var(--radius-md)}.client-mode-toggle button{padding:var(--space-1-5) var(--space-3);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--foreground-muted);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.client-mode-toggle button.active{background:var(--background);color:var(--color-primary);font-weight:var(--font-medium);box-shadow:var(--shadow-sm)}.lignes-container{display:flex;flex-direction:column;gap:var(--space-3)}.ligne-item{background:var(--background-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-3);transition:all var(--transition-fast)}.ligne-item:hover{border-color:var(--border)}.ligne-main{display:flex;gap:var(--space-2);margin-bottom:var(--space-2)}.ligne-designation{flex:1;padding:var(--space-2) var(--space-3);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--foreground);font-size:var(--text-sm);font-family:var(--font-body);outline:none;transition:all var(--transition-fast)}.ligne-designation:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.btn-remove-ligne{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--foreground-muted);cursor:pointer;transition:all var(--transition-fast)}.btn-remove-ligne:hover{background:var(--color-error-subtle);border-color:var(--color-error);color:var(--color-error)}.ligne-details{display:flex;align-items:center;gap:var(--space-2)}.ligne-field{display:flex;align-items:center;gap:var(--space-1)}.ligne-field input,.ligne-field select{padding:var(--space-1-5) var(--space-2);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--foreground);font-size:var(--text-sm);font-family:var(--font-body);outline:none;transition:all var(--transition-fast)}.ligne-field input{width:60px;text-align:right}.ligne-field select{width:80px}.ligne-field--prix{position:relative}.ligne-field--prix input{width:80px;padding-right:var(--space-8)}.ligne-field--prix .currency{position:absolute;right:var(--space-2);font-size:var(--text-xs);color:var(--foreground-muted)}.ligne-total{margin-left:auto;padding:var(--space-1-5) var(--space-3);background:var(--color-primary-subtle);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-primary);white-space:nowrap}.btn-add-ligne{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1-5) var(--space-3);background:transparent;border:1px dashed var(--border);border-radius:var(--radius-md);color:var(--color-primary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.btn-add-ligne:hover{background:var(--color-primary-subtle);border-color:var(--color-primary)}.tva-row{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-subtle)}.tva-row label{font-size:var(--text-sm);color:var(--foreground-muted)}.tva-row select{padding:var(--space-1-5) var(--space-3);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--foreground);font-size:var(--text-sm);font-family:var(--font-body);outline:none;cursor:pointer}.modal-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-subtle);background:var(--background)}.totaux-summary{display:flex;align-items:baseline;gap:var(--space-2)}.totaux-label{font-size:var(--text-sm);color:var(--foreground-muted)}.totaux-value{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--foreground)}.footer-actions{display:flex;gap:var(--space-2)}.btn-cancel{padding:var(--space-2) var(--space-4);background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--foreground-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.btn-cancel:hover{background:var(--background-secondary);border-color:var(--border-hover)}.btn-submit{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-primary);border:none;border-radius:var(--radius-md);color:var(--color-primary-foreground);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast)}.btn-submit:hover:not(:disabled){background:var(--color-primary-hover)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.modal-preview-panel{width:440px;flex-shrink:0;display:flex;flex-direction:column;background:var(--background-secondary);max-height:90vh}.preview-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--foreground-muted)}.invoice-preview{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-3)}.invoice-preview .facture-unifiee{width:100%}.invoice-preview .facture-unifiee-page{width:100%;min-height:auto;padding-bottom:40px}.invoice-preview .facture-unifiee--preview{max-width:100%;box-shadow:var(--shadow-lg);border-radius:var(--radius-md)}.invoice-preview .facture-unifiee-header{padding:16px 20px 12px}.invoice-preview .facture-unifiee-logo{width:50px}.invoice-preview .facture-unifiee-entreprise-nom{font-size:14px}.invoice-preview .facture-unifiee-entreprise{font-size:9px}.invoice-preview .facture-unifiee-info-section{padding:12px 20px;flex-direction:column;gap:16px}.invoice-preview .facture-unifiee-section-title{font-size:10px;margin-bottom:8px}.invoice-preview .facture-unifiee-client{font-size:9px}.invoice-preview .facture-unifiee-client-nom{font-size:11px}.invoice-preview .facture-unifiee-meta{text-align:left}.invoice-preview .facture-unifiee-meta-row{justify-content:flex-start;gap:12px;margin-bottom:4px}.invoice-preview .facture-unifiee-meta-label{font-size:10px}.invoice-preview .facture-unifiee-meta-value{font-size:11px;min-width:auto}.invoice-preview .facture-unifiee-separator{margin:0 20px}.invoice-preview .facture-unifiee-table-section{padding:16px 20px}.invoice-preview .facture-unifiee-table thead th{font-size:9px;padding:8px 0}.invoice-preview .facture-unifiee-table tbody td{font-size:10px;padding:10px 0}.invoice-preview .facture-unifiee-totals-section{padding:0 20px}.invoice-preview .facture-unifiee-totals{width:100%}.invoice-preview .facture-unifiee-total-row{padding:4px 0}.invoice-preview .facture-unifiee-total-label,.invoice-preview .facture-unifiee-total-value{font-size:11px}.invoice-preview .facture-unifiee-ttc-section{padding:16px 20px 40px}.invoice-preview .facture-unifiee-ttc{padding:16px 0}.invoice-preview .facture-unifiee-ttc-label{font-size:14px}.invoice-preview .facture-unifiee-ttc-value{font-size:20px}.invoice-preview .facture-unifiee-header-bar,.invoice-preview .facture-unifiee-footer-bar{height:8px}.invoice-paper{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-6);min-height:600px}.invoice-company{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:2px solid #4F46E5}.company-logo{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#4f46e5;color:#fff;font-weight:700;font-size:18px;border-radius:8px}.company-info h4{margin:0 0 4px;font-size:16px;font-weight:700;color:#1c1917}.company-info p{margin:0;font-size:11px;color:#78716c;line-height:1.4}.invoice-badge{display:inline-block;padding:4px 12px;background:#4f46e5;color:#fff;font-size:10px;font-weight:700;letter-spacing:.1em;border-radius:4px;margin-bottom:16px}.invoice-meta{display:flex;gap:24px;margin-bottom:20px}.meta-item{display:flex;flex-direction:column;gap:2px}.meta-label{font-size:10px;font-weight:600;color:#a8a29e;text-transform:uppercase;letter-spacing:.05em}.meta-value{font-size:12px;font-weight:600;color:#1c1917}.invoice-client{background:#fafaf9;border-radius:8px;padding:16px;margin-bottom:16px}.client-label{display:block;font-size:10px;font-weight:600;color:#a8a29e;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.client-details strong{display:block;font-size:14px;color:#1c1917;margin-bottom:4px}.client-details p{margin:0;font-size:12px;color:#57534e;line-height:1.4}.client-siret{font-size:11px!important;color:#a8a29e!important;margin-top:4px!important}.invoice-objet{font-size:12px;color:#57534e;margin-bottom:16px;padding:12px;background:#f5f5f4;border-radius:6px;border-left:3px solid #4F46E5}.objet-label{font-weight:600;color:#78716c}.invoice-lines{margin-bottom:16px}.lines-header{display:grid;grid-template-columns:1fr 60px 70px 80px;gap:8px;padding:8px 0;border-bottom:1px solid #E7E5E4;font-size:10px;font-weight:600;color:#78716c;text-transform:uppercase;letter-spacing:.05em}.lines-header span:not(:first-child){text-align:right}.lines-row{display:grid;grid-template-columns:1fr 60px 70px 80px;gap:8px;padding:10px 0;border-bottom:1px solid #F5F5F4;font-size:12px;color:#1c1917}.lines-row span:not(:first-child){text-align:right}.line-designation{font-weight:500}.line-qte,.line-prix{color:#57534e}.line-total{font-weight:600;font-family:var(--font-mono)}.lines-empty{padding:24px;text-align:center;font-size:12px;color:#a8a29e;font-style:italic}.invoice-totals{margin-left:auto;width:200px;background:#fafaf9;border-radius:8px;padding:12px 16px}.total-line{display:flex;justify-content:space-between;padding:6px 0;font-size:12px;color:#57534e}.total-line span:last-child{font-family:var(--font-mono);font-weight:500}.total-line--ttc{margin-top:8px;padding-top:8px;border-top:1px solid #E7E5E4;font-weight:700;color:#1c1917;font-size:14px}.total-line--ttc span:last-child{color:#4f46e5;font-weight:700}.invoice-conditions{margin-top:20px;padding:12px;background:#f5f5f4;border-radius:6px;font-size:11px;color:#78716c;text-align:center}@media(max-width:1024px){.modal-preview-panel{display:none}.split-view-modal,.split-view-modal.with-preview{max-width:560px}.btn-toggle-preview{display:none}.modal-form-panel{border-right:none}}@media(max-width:640px){.modal-overlay{padding:0}.split-view-modal{max-width:100%;max-height:100vh;border-radius:0}.form-row,.form-row--stacked .form-row{grid-template-columns:1fr}.ligne-details{flex-wrap:wrap}.ligne-total{width:100%;text-align:center;margin-top:var(--space-2);margin-left:0}.modal-footer{flex-direction:column;gap:var(--space-3)}.totaux-summary{width:100%;justify-content:space-between;padding-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle)}.footer-actions{width:100%}.footer-actions button{flex:1}}[data-theme=dark] .modal-form-panel{background:var(--card)}[data-theme=dark] .modal-header,[data-theme=dark] .modal-footer,[data-theme=dark] .modal-preview-panel{background:var(--background)}[data-theme=dark] .invoice-paper{background:var(--card);border:1px solid var(--border)}[data-theme=dark] .company-info h4,[data-theme=dark] .meta-value,[data-theme=dark] .client-details strong,[data-theme=dark] .lines-row,[data-theme=dark] .line-designation,[data-theme=dark] .total-line--ttc{color:var(--foreground)}[data-theme=dark] .company-info p,[data-theme=dark] .meta-label,[data-theme=dark] .client-label,[data-theme=dark] .client-details p,[data-theme=dark] .objet-label,[data-theme=dark] .lines-header,[data-theme=dark] .line-qte,[data-theme=dark] .line-prix,[data-theme=dark] .total-line,[data-theme=dark] .lines-empty,[data-theme=dark] .invoice-conditions{color:var(--foreground-muted)}[data-theme=dark] .invoice-company{border-color:var(--color-primary)}[data-theme=dark] .invoice-client,[data-theme=dark] .invoice-totals{background:var(--background-secondary)}[data-theme=dark] .invoice-objet,[data-theme=dark] .invoice-conditions{background:var(--background-tertiary)}[data-theme=dark] .lines-header{border-color:var(--border)}[data-theme=dark] .lines-row{border-color:var(--border-subtle)}[data-theme=dark] .total-line--ttc{border-color:var(--border)}.facture-detail-modal{background:var(--bg-card);border-radius:var(--radius-xl);width:100%;max-width:1000px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-xl)}.facture-detail-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.facture-detail-modal .modal-header-content{display:flex;align-items:center;gap:var(--spacing-md)}.facture-detail-modal .modal-header-content svg{color:var(--color-primary)}.facture-detail-modal .modal-header-content h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.facture-detail-modal .modal-header-content .statut-badge{margin-left:var(--spacing-sm)}.modal-tabs{display:flex;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-xl);border-bottom:1px solid var(--border-color);background:var(--bg-card)}.modal-tabs button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.modal-tabs button:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-tabs button.active{background:var(--color-primary);color:#fff}.facture-detail-modal .modal-body{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);gap:var(--spacing-md);color:var(--text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.tab-apercu{display:flex;justify-content:center}.apercu-preview{max-width:100%;overflow:auto;border:1px solid var(--border-color);border-radius:var(--radius-md);background:#fff}.tab-details{display:flex;flex-direction:column;gap:var(--spacing-xl)}.details-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}.detail-section{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-lg)}.detail-section h4{margin:0 0 var(--spacing-md) 0;font-size:.875rem;font-weight:600;color:var(--text-primary);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.detail-rows{display:flex;flex-direction:column;gap:var(--spacing-sm)}.detail-row{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.detail-label{color:var(--text-muted)}.detail-value{color:var(--text-primary);font-weight:500}.detail-section--montants{background:linear-gradient(135deg,#3b82f61a,#8b5cf61a)}.montants-summary{display:flex;flex-direction:column;gap:var(--spacing-sm)}.montant-row{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:var(--text-secondary)}.montant-row--ttc{font-size:1rem;font-weight:600;color:var(--text-primary);padding-top:var(--spacing-sm);border-top:1px solid var(--border-color);margin-top:var(--spacing-sm)}.detail-section--lignes{grid-column:span 3}.lignes-table{width:100%;border-collapse:collapse;margin-top:var(--spacing-md)}.lignes-table th,.lignes-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-size:.875rem}.lignes-table th{color:var(--text-muted);font-weight:500;border-bottom:1px solid var(--border-color)}.lignes-table td{color:var(--text-primary);border-bottom:1px solid var(--border-color)}.lignes-table tr:last-child td{border-bottom:none}.notes-content{margin:0;font-size:.875rem;color:var(--text-secondary);white-space:pre-wrap}.tab-ordres{overflow-x:auto}.ordres-table{width:100%;border-collapse:collapse}.ordres-table th,.ordres-table td{padding:var(--spacing-md);text-align:left;font-size:.875rem;border-bottom:1px solid var(--border-color)}.ordres-table th{color:var(--text-muted);font-weight:600;background:var(--bg-secondary)}.ordres-table td{color:var(--text-primary)}.icon-success{color:#10b981}.icon-warning{color:#f59e0b}.tab-documents{padding:0}.documents-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.document-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border-radius:var(--radius-md);transition:background var(--transition-fast)}.document-item:hover{background:var(--bg-primary)}.document-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border-radius:var(--radius-md);color:var(--color-primary)}.document-info{flex:1;display:flex;flex-direction:column}.document-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.document-type{font-size:.75rem;color:var(--text-muted);text-transform:capitalize}.document-action{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-muted);text-decoration:none;transition:all var(--transition-fast)}.document-action:hover{background:var(--bg-card);color:var(--color-primary)}.facture-detail-modal .modal-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.footer-left,.footer-right{display:flex;gap:var(--spacing-sm)}.btn-secondary{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.btn-secondary:hover{border-color:var(--text-muted);color:var(--text-primary)}.btn-primary{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-success{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#10b981;border:none;border-radius:var(--radius-md);color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-success:hover{background:#059669}.btn-danger{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid #ef4444;border-radius:var(--radius-md);color:#ef4444;font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.btn-danger:hover{background:#ef44441a}.statut-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:500}.statut-badge--editee{background:#6b72801a;color:#6b7280}.statut-badge--validee{background:#3b82f61a;color:#3b82f6}.statut-badge--payee{background:#10b9811a;color:#10b981}.statut-badge--annulee{background:#ef44441a;color:#ef4444}@media(max-width:768px){.facture-detail-modal{max-width:100%;max-height:100vh;border-radius:0}.details-grid{grid-template-columns:1fr}.detail-section--lignes{grid-column:span 1}.modal-tabs{overflow-x:auto}.facture-detail-modal .modal-footer{flex-direction:column;gap:var(--spacing-md)}.footer-left,.footer-right{width:100%;justify-content:center}}@media print{.modal-overlay{position:static;background:none;padding:0}.facture-detail-modal{box-shadow:none;max-height:none}.modal-header,.modal-tabs,.modal-footer{display:none}.modal-body{padding:0}.apercu-preview{border:none}}.facturation-page{min-height:100vh;background:var(--background-secondary)}.facturation-page .page-content{padding:var(--space-6);max-width:1600px;margin:0 auto}.facturation-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-6);padding:0 var(--space-6)}.facturation-stats .stat-card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4);position:relative;overflow:hidden;transition:all var(--transition-normal)}.facturation-stats .stat-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.facturation-stats .stat-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%}.stat-card--total:before{background:var(--color-primary)}.stat-card--attente:before{background:var(--color-warning)}.stat-card--payees:before{background:var(--color-success)}.stat-card--ca:before{background:#8b5cf6}.stat-card-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card--total .stat-card-icon{background:var(--color-primary-subtle);color:var(--color-primary)}.stat-card--attente .stat-card-icon{background:var(--color-warning-subtle);color:var(--color-warning)}.stat-card--payees .stat-card-icon{background:var(--color-success-subtle);color:var(--color-success)}.stat-card--ca .stat-card-icon{background:#8b5cf61a;color:#8b5cf6}.stat-card-content{display:flex;flex-direction:column;flex:1;gap:var(--space-0-5)}.stat-card-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--foreground);line-height:1.2}.stat-card-label{font-size:var(--text-sm);color:var(--foreground-muted)}.stat-card-amount{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--foreground-secondary);position:absolute;top:var(--space-4);right:var(--space-4)}.facturation-toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4);padding:0 var(--space-6);margin-bottom:var(--space-4);flex-wrap:wrap}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:var(--space-3)}.facturation-toolbar .search-box{display:flex;align-items:center;gap:var(--space-2);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-2-5) var(--space-3);min-width:280px;transition:all var(--transition-fast)}.facturation-toolbar .search-box:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 var(--ring-offset) var(--background),0 0 0 calc(var(--ring-offset) + var(--ring-width)) var(--ring-color)}.facturation-toolbar .search-box svg{color:var(--foreground-muted);flex-shrink:0}.facturation-toolbar .search-box input{border:none;background:transparent;outline:none;color:var(--foreground);font-size:var(--text-sm);font-family:var(--font-body);width:100%}.facturation-toolbar .search-box input::placeholder{color:var(--foreground-muted)}.btn-filter,.btn-refresh{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2-5) var(--space-3);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--foreground-secondary);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-body);transition:all var(--transition-fast)}.btn-filter:hover,.btn-refresh:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-filter.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-foreground)}.btn-filter svg.rotated{transform:rotate(180deg)}.btn-refresh{padding:var(--space-2-5)}.btn-refresh svg.spinning{animation:spin 1s linear infinite}.facturation-toolbar .btn-primary{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2-5) var(--space-4);background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:var(--color-primary-foreground);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);font-family:var(--font-body);transition:all var(--transition-fast)}.facturation-toolbar .btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2-5) var(--space-4);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--foreground-secondary);cursor:pointer;font-size:var(--text-sm);font-family:var(--font-body);transition:all var(--transition-fast)}.btn-secondary:hover{border-color:var(--border-hover);color:var(--foreground)}.facturation-filters{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);padding:var(--space-5);margin:0 var(--space-6) var(--space-4);display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-4);animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.filter-group{display:flex;flex-direction:column;gap:var(--space-1-5)}.filter-group label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--foreground-muted);text-transform:uppercase;letter-spacing:.05em}.filter-group select,.filter-group input{padding:var(--space-2-5) var(--space-3);background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--foreground);font-size:var(--text-sm);font-family:var(--font-body);outline:none;transition:border-color var(--transition-fast)}.filter-group select:focus,.filter-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 var(--ring-offset) var(--background),0 0 0 calc(var(--ring-offset) + var(--ring-width)) var(--ring-color)}.filter-actions{display:flex;align-items:flex-end;gap:var(--space-3);grid-column:span 2}.facturation-table-container{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-xl);overflow:hidden;margin:0 var(--space-6)}.error-banner{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-error-subtle);color:var(--color-error);border-bottom:1px solid var(--color-error)}.loading-state,.facturation-table-container .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12);color:var(--foreground-muted);gap:var(--space-4)}.facturation-table-container .empty-state svg{opacity:.5}.facturation-table-container .empty-state h3{color:var(--foreground);margin:0;font-size:var(--text-lg)}.facturation-table-container .empty-state p{margin:0;font-size:var(--text-sm)}.facturation-table{width:100%;border-collapse:collapse}.facturation-table thead{background:var(--background-secondary);border-bottom:1px solid var(--border)}.facturation-table th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--foreground-muted);text-transform:uppercase;letter-spacing:.05em}.facturation-table tbody tr{border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background var(--transition-fast)}.facturation-table tbody tr:hover{background:var(--interactive-hover)}.facturation-table tbody tr:last-child{border-bottom:none}.facturation-table td{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--foreground)}.cell-numero{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-medium)}.cell-numero svg{color:var(--color-primary)}.cell-client{display:flex;align-items:center;gap:var(--space-2)}.cell-client svg{color:var(--foreground-muted)}.cell-montant{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.cell-montant--ttc{font-weight:var(--font-semibold)}.type-badge{display:inline-flex;padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.type-badge--auto{background:#8b5cf61a;color:#8b5cf6}.type-badge--manuelle{background:var(--color-primary-subtle);color:var(--color-primary)}.statut-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2-5);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.statut-badge--editee{background:var(--background-tertiary);color:var(--foreground-muted)}.statut-badge--validee{background:var(--color-info-subtle);color:var(--color-info)}.statut-badge--envoyee{background:#8b5cf61a;color:#8b5cf6}.statut-badge--payee{background:var(--color-success-subtle);color:var(--color-success)}.statut-badge--annulee{background:var(--color-error-subtle);color:var(--color-error)}.cell-actions{position:relative}.btn-action{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--foreground-muted);cursor:pointer;transition:all var(--transition-fast)}.btn-action:hover{background:var(--background-tertiary);color:var(--foreground)}.action-menu{position:absolute;top:100%;right:0;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:180px;z-index:var(--z-popover);overflow:hidden;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.action-menu button,.action-menu a{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2-5) var(--space-4);background:transparent;border:none;color:var(--foreground);font-size:var(--text-sm);font-family:var(--font-body);cursor:pointer;text-decoration:none;transition:background var(--transition-fast)}.action-menu button:hover,.action-menu a:hover{background:var(--interactive-hover)}.action-menu button svg,.action-menu a svg{color:var(--foreground-muted)}.action-menu .action-danger{color:var(--color-error)}.action-menu .action-danger svg{color:var(--color-error)}.action-menu .action-danger:hover{background:var(--color-error-subtle)}.menu-overlay{position:fixed;inset:0;z-index:calc(var(--z-popover) - 1)}@media(max-width:1200px){.facturation-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.facturation-stats{grid-template-columns:1fr;padding:0 var(--space-4)}.facturation-toolbar{flex-direction:column;align-items:stretch;padding:0 var(--space-4)}.toolbar-left,.toolbar-right{flex-wrap:wrap}.facturation-toolbar .search-box{min-width:100%}.facturation-filters{margin:0 var(--space-4) var(--space-4)}.facturation-table-container{margin:0 var(--space-4);overflow-x:auto}.facturation-table{min-width:800px}}[data-theme=dark] .facturation-page{background:var(--background)}[data-theme=dark] .facturation-stats .stat-card,[data-theme=dark] .facturation-filters,[data-theme=dark] .facturation-table-container{background:var(--card);border-color:var(--card-border)}.auth-container{position:fixed;inset:0;z-index:var(--z-notification);display:flex;align-items:center;justify-content:center;min-height:100vh;overflow:auto}.auth-background{position:absolute;inset:0;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);z-index:-2}.auth-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 25% 25%,rgba(59,130,246,.05) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(139,92,246,.05) 0%,transparent 50%);z-index:-1}.auth-gradient{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 0%,rgba(248,250,252,.3) 100%)}.auth-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2xl);padding:var(--spacing-xl);width:100%;max-width:480px;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-logo{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);text-align:center}.logo-image{width:380px;height:240px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.06))}.auth-card{width:100%;background:var(--bg-card);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-card, 16px);padding:var(--spacing-2xl);box-shadow:var(--shadow-lg);position:relative;overflow:hidden;animation:cardSlideUp .6s ease-out .1s both}@keyframes cardSlideUp{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary-500, var(--color-primary)),transparent)}.auth-header{text-align:center;margin-bottom:var(--spacing-2xl)}.auth-header h1{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.auth-header p{font-size:.875rem;color:var(--text-secondary)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm);animation:fadeInUp .5s ease-out forwards;opacity:0}.form-group:nth-child(1){animation-delay:.3s}.form-group:nth-child(2){animation-delay:.4s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.form-group label{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.auth-form .input{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-family:var(--font-body);font-size:1rem;color:var(--text-primary);background:var(--bg-surface);border:2px solid var(--border-color);border-radius:var(--radius-button, 10px);outline:none;transition:all var(--transition-base)}.auth-form .input::placeholder{color:var(--text-muted);font-weight:400}.auth-form .input:focus{border-color:var(--primary-500, var(--color-primary));background:var(--bg-primary);box-shadow:0 0 0 4px #3b82f61a;transform:translateY(-1px)}.auth-form .input:hover:not(:focus){border-color:var(--border-color-hover);background:var(--bg-primary)}.auth-submit{margin-top:var(--spacing-md);padding:var(--spacing-md) var(--spacing-xl);font-size:1rem;font-weight:600;height:48px;background:var(--primary-500, var(--color-primary));color:#fff;border:none;border-radius:var(--radius-button, 10px);cursor:pointer;position:relative;overflow:hidden;animation:fadeInUp .5s ease-out .5s both;transition:all var(--transition-base);box-shadow:0 4px 12px #3b82f633}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #3b82f64d;background:var(--primary-600, var(--color-primary-hover))}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-error{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:var(--color-error);font-size:.875rem;margin-bottom:var(--spacing-md);animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.auth-footer{text-align:center;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--border-color)}.auth-footer p{color:var(--text-secondary);font-size:.875rem}.auth-toggle{background:none;border:none;color:var(--primary-500, var(--color-primary));font-weight:600;cursor:pointer;text-decoration:none;margin-left:var(--spacing-xs);transition:color var(--transition-fast)}.auth-toggle:hover{color:var(--primary-600, var(--color-primary-hover));text-decoration:underline}@media(max-width:768px){.auth-content{padding:var(--spacing-md);gap:var(--spacing-xl)}.auth-card{padding:var(--spacing-xl)}.form-row{grid-template-columns:1fr}.logo-image{width:280px;height:180px}}@media(max-width:480px){.auth-content{padding:var(--spacing-sm)}.auth-card{padding:var(--spacing-lg)}.auth-header h1{font-size:1.5rem}}
