@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--action: #2563eb;--action-hover: #1d4ed8;--action-light: #dbeafe;--action-bg: rgba(37, 99, 235, .08);--action-glow: rgba(37, 99, 235, .25);--error: #dc2626;--error-hover: #b91c1c;--error-light: #fef2f2;--error-bg: rgba(220, 38, 38, .08);--warning: #f59e0b;--warning-hover: #d97706;--warning-light: #fffbeb;--warning-bg: rgba(245, 158, 11, .08);--success: #16a34a;--success-hover: #15803d;--success-light: #f0fdf4;--success-bg: rgba(22, 163, 74, .08);--info: #0ea5e9;--info-hover: #0284c7;--info-light: #f0f9ff;--info-bg: rgba(14, 165, 233, .08);--bg: #ffffff;--bg-section: #f8f9fb;--bg-hover: #f1f3f8;--bg-elevated: #ffffff;--surface: #ffffff;--surface-hover: #f8f9fb;--border: #e2e5ec;--border-light: #f0f1f5;--border-focus: var(--action);--text: #0f1729;--text-secondary: #374151;--text-light: #6b7280;--text-muted: #9ca3af;--text-inverse: #ffffff;--nav-bg: #0f172a;--nav-bg-hover: #1e293b;--nav-text: #94a3b8;--nav-text-active: #ffffff;--nav-accent: #2563eb;--nav-border: #1e293b;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--space-3xl: 3rem;--radius-sm: 6px;--radius: 8px;--radius-card: 12px;--radius-lg: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .03), 0 1px 1px rgba(0, 0, 0, .02);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .03);--shadow: 0 2px 8px rgba(0, 0, 0, .04), 0 4px 16px rgba(0, 0, 0, .03);--shadow-md: 0 4px 12px rgba(0, 0, 0, .05), 0 8px 24px rgba(0, 0, 0, .04);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .06), 0 16px 48px rgba(0, 0, 0, .04);--shadow-overlay: 0 24px 48px -12px rgba(0, 0, 0, .18), 0 0 0 1px rgba(0, 0, 0, .03);--shadow-inset: inset 0 2px 4px rgba(0, 0, 0, .04), inset 0 0 0 1px rgba(0, 0, 0, .02);--shadow-lift: 0 8px 30px rgba(0, 0, 0, .08), 0 2px 8px rgba(0, 0, 0, .04);--shadow-glow: 0 0 0 3px var(--action-glow);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--transition-fast: .15s var(--ease-out);--transition: .2s var(--ease-out);--transition-slow: .35s var(--ease-out);--transition-spring: .3s var(--ease-spring);--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--sidebar-width: 240px;--header-height: 60px;--bottom-nav-height: 64px}html.dark{color-scheme:dark;--action: #3b82f6;--action-hover: #60a5fa;--action-light: rgba(59, 130, 246, .15);--action-bg: rgba(59, 130, 246, .1);--action-glow: rgba(59, 130, 246, .3);--error: #ef4444;--error-hover: #f87171;--error-light: rgba(239, 68, 68, .12);--error-bg: rgba(239, 68, 68, .08);--warning: #f59e0b;--warning-hover: #fbbf24;--warning-light: rgba(245, 158, 11, .12);--warning-bg: rgba(245, 158, 11, .08);--success: #22c55e;--success-hover: #4ade80;--success-light: rgba(34, 197, 94, .12);--success-bg: rgba(34, 197, 94, .08);--info: #38bdf8;--info-hover: #7dd3fc;--info-light: rgba(56, 189, 248, .12);--info-bg: rgba(56, 189, 248, .08);--bg: #0b1120;--bg-section: #111827;--bg-hover: #1a2236;--bg-elevated: #162032;--surface: #141c2e;--surface-hover: #1a2540;--border: #1f2d45;--border-light: #172035;--border-focus: var(--action);--text: #f0f4f8;--text-secondary: #c1cbd8;--text-light: #8899ad;--text-muted: #556678;--nav-bg: #070d1a;--nav-bg-hover: #111827;--nav-border: #1a2236;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3), 0 0 0 1px rgba(255, 255, 255, .02);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .03);--shadow: 0 2px 10px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .03);--shadow-md: 0 4px 16px rgba(0, 0, 0, .45), 0 0 0 1px rgba(255, 255, 255, .03);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .04);--shadow-overlay: 0 24px 64px rgba(0, 0, 0, .6), 0 0 0 1px rgba(255, 255, 255, .05);--shadow-inset: inset 0 2px 4px rgba(0, 0, 0, .3), inset 0 0 0 1px rgba(255, 255, 255, .03);--shadow-lift: 0 12px 40px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .05)}@media(prefers-color-scheme:dark){html:not(.light){color-scheme:dark;--action: #3b82f6;--action-hover: #60a5fa;--action-light: rgba(59, 130, 246, .15);--action-bg: rgba(59, 130, 246, .1);--action-glow: rgba(59, 130, 246, .3);--error: #ef4444;--error-hover: #f87171;--error-light: rgba(239, 68, 68, .12);--error-bg: rgba(239, 68, 68, .08);--warning: #f59e0b;--warning-hover: #fbbf24;--warning-light: rgba(245, 158, 11, .12);--warning-bg: rgba(245, 158, 11, .08);--success: #22c55e;--success-hover: #4ade80;--success-light: rgba(34, 197, 94, .12);--success-bg: rgba(34, 197, 94, .08);--info: #38bdf8;--info-hover: #7dd3fc;--info-light: rgba(56, 189, 248, .12);--info-bg: rgba(56, 189, 248, .08);--bg: #0b1120;--bg-section: #111827;--bg-hover: #1a2236;--bg-elevated: #162032;--surface: #141c2e;--surface-hover: #1a2540;--border: #1f2d45;--border-light: #172035;--border-focus: var(--action);--text: #f0f4f8;--text-secondary: #c1cbd8;--text-light: #8899ad;--text-muted: #556678;--nav-bg: #070d1a;--nav-bg-hover: #111827;--nav-border: #1a2236;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3), 0 0 0 1px rgba(255, 255, 255, .02);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .03);--shadow: 0 2px 10px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .03);--shadow-md: 0 4px 16px rgba(0, 0, 0, .45), 0 0 0 1px rgba(255, 255, 255, .03);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .04);--shadow-overlay: 0 24px 64px rgba(0, 0, 0, .6), 0 0 0 1px rgba(255, 255, 255, .05);--shadow-inset: inset 0 2px 4px rgba(0, 0, 0, .3), inset 0 0 0 1px rgba(255, 255, 255, .03);--shadow-lift: 0 12px 40px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .05)}}[data-theme=dark]{color-scheme:dark;--action: #3b82f6;--action-hover: #60a5fa;--action-light: rgba(59, 130, 246, .15);--action-bg: rgba(59, 130, 246, .1);--action-glow: rgba(59, 130, 246, .3);--bg: #0b1120;--bg-section: #111827;--bg-hover: #1a2236;--bg-elevated: #162032;--surface: #141c2e;--surface-hover: #1a2540;--border: #1f2d45;--border-light: #172035;--text: #f0f4f8;--text-secondary: #c1cbd8;--text-light: #8899ad;--text-muted: #556678;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3), 0 0 0 1px rgba(255, 255, 255, .02);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .03);--shadow: 0 2px 10px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255, 255, 255, .03);--shadow-md: 0 4px 16px rgba(0, 0, 0, .45), 0 0 0 1px rgba(255, 255, 255, .03);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .04);--shadow-overlay: 0 24px 64px rgba(0, 0, 0, .6), 0 0 0 1px rgba(255, 255, 255, .05);--shadow-inset: inset 0 2px 4px rgba(0, 0, 0, .3), inset 0 0 0 1px rgba(255, 255, 255, .03);--shadow-lift: 0 12px 40px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255, 255, 255, .05)}*,*: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;scroll-behavior:smooth}body{font-family:var(--font);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text);background:var(--bg);min-height:100vh;transition:background-color .3s var(--ease-out),color .3s var(--ease-out)}img,svg,video{display:block;max-width:100%}a{color:inherit;text-decoration:none;transition:color var(--transition-fast),opacity var(--transition-fast)}a:hover{opacity:.85}button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font:inherit;color:inherit}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:var(--leading-tight);color:var(--text);letter-spacing:-.01em}h1{font-size:var(--text-3xl);letter-spacing:-.02em}h2{font-size:var(--text-2xl);letter-spacing:-.015em}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}p{color:var(--text-secondary)}:focus{outline:none}:focus-visible{outline:2px solid var(--action);outline-offset:3px;border-radius:var(--radius-sm);box-shadow:var(--shadow-glow);transition:outline-offset var(--transition-fast),box-shadow var(--transition-fast)}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:none;border-color:var(--action);box-shadow:0 0 0 3px var(--action-glow),var(--shadow-sm)}button,[role=button],.btn,a[class*=btn]{transition:background-color var(--transition),color var(--transition-fast),border-color var(--transition),box-shadow var(--transition),transform var(--transition-spring),opacity var(--transition-fast);will-change:transform}button:hover,[role=button]:hover,.btn:hover,a[class*=btn]:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}button:active,[role=button]:active,.btn:active,a[class*=btn]:active{transform:translateY(0) scale(.98);transition-duration:80ms}.card,[class*=card],[class*=Card]{transition:box-shadow var(--transition),transform var(--transition-spring),border-color var(--transition),background-color var(--transition);will-change:transform,box-shadow}.card:hover,[class*=card]:hover,[class*=Card]:hover{transform:translateY(-2px) scale(1.02);box-shadow:var(--shadow-lift);border-color:var(--border)}a:not(.btn):not([class*=btn]):not(.card):not([class*=card]){transition:color var(--transition-fast),text-decoration-color var(--transition-fast)}a:not(.btn):not([class*=btn]):not(.card):not([class*=card]):hover{color:var(--action);opacity:1}input,textarea,select{transition:border-color var(--transition),box-shadow var(--transition),background-color var(--transition)}input[type=checkbox],input[type=radio]{transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}button svg,a svg,[role=button] svg{transition:transform var(--transition-spring),color var(--transition-fast)}button:hover svg,a:hover svg,[role=button]:hover svg{transform:scale(1.1)}nav a,nav button,[class*=nav] a,[class*=nav] button,[class*=Nav] a,[class*=Nav] button,[class*=sidebar] a,[class*=sidebar] button,[class*=Sidebar] a,[class*=Sidebar] button{transition:background-color var(--transition),color var(--transition-fast),box-shadow var(--transition),border-color var(--transition),padding-left var(--transition)}tr{transition:background-color var(--transition-fast)}tbody tr:hover{background-color:var(--bg-hover)}[class*=badge],[class*=Badge],[class*=tag],[class*=Tag],[class*=chip],[class*=Chip]{transition:background-color var(--transition-fast),color var(--transition-fast),transform var(--transition-spring),box-shadow var(--transition-fast)}[class*=badge]:hover,[class*=Badge]:hover,[class*=tag]:hover,[class*=Tag]:hover{transform:scale(1.05)}[class*=dropdown],[class*=Dropdown],[class*=menu],[class*=Menu],[class*=popover],[class*=Popover]{animation:ds-fade-in .2s var(--ease-out)}[class*=modal],[class*=Modal],dialog,[role=dialog]{animation:ds-scale-in .25s var(--ease-out)}[class*=tooltip],[class*=Tooltip]{animation:ds-fade-up .15s var(--ease-out)}@keyframes ds-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes ds-scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes ds-fade-up{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes ds-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton,[class*=skeleton],[class*=Skeleton]{background:linear-gradient(90deg,var(--bg-section) 25%,var(--bg-hover) 50%,var(--bg-section) 75%);background-size:200% 100%;animation:ds-shimmer 1.5s infinite;border-radius:var(--radius)}html,body{max-width:100vw;overflow-x:hidden}img{max-width:100%;height:auto}input,textarea,select{max-width:100%}p,h1,h2,h3,h4,h5,h6,span,div,td,th,li{word-break:break-word}::selection{background:var(--action);color:#fff}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full);transition:background var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}*{scrollbar-width:thin;scrollbar-color:var(--text-muted) transparent}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.card:hover,[class*=card]:hover,[class*=Card]:hover,button:hover,[role=button]:hover{transform:none!important}}@media(min-width:769px){.desktop-only{display:inline-flex!important}}@media(max-width:768px){.desktop-only{display:none!important}}@media print{.sidebar,.bottom-nav,.header,.fab,.tooltip,.notif-dropdown,.command-palette,.toast-container,.skip-to-content,[aria-label=Menu],.header-actions,.sidebar-toggle,.mini-sidebar,button.print-hide,.no-print{display:none!important}.main-content,.page-content,main,#main-content{margin:0!important;padding:8mm!important;width:100%!important;max-width:100%!important}body{background:#fff!important;color:#000!important;font-size:11pt!important;line-height:1.4!important}.card,.kpi-card,.stat-card,[class*=card]{box-shadow:none!important;border:1px solid #ccc!important;break-inside:avoid;page-break-inside:avoid}table{border-collapse:collapse;width:100%}th,td{border:1px solid #999!important;padding:4px 8px!important;font-size:10pt!important}th{background:#f0f0f0!important;color:#000!important;font-weight:600}tr:nth-child(2n){background:#f9f9f9!important}svg{max-width:100%;height:auto;print-color-adjust:exact;-webkit-print-color-adjust:exact}a[href^=http]:after{content:" (" attr(href) ")";font-size:9pt;color:#666}a{color:#000!important;text-decoration:underline}h1,h2,h3{page-break-after:avoid}.page-break{page-break-before:always}.dark,.dark *{background:#fff!important;color:#000!important}.badge,.status-badge,[class*=badge]{print-color-adjust:exact;-webkit-print-color-adjust:exact;border:1px solid currentColor!important}@page{margin:15mm;@bottom-center{content:"QualityApp — " counter(page) "/" counter(pages);font-size:9pt}}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:.625rem 1.25rem;font-size:var(--text-sm);font-weight:600;line-height:1;border-radius:var(--radius);transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:2px solid transparent}.btn:active{transform:scale(.97)}.btn-primary{background:var(--action);color:#fff}.btn-primary:hover{background:var(--action-hover);box-shadow:var(--shadow-sm)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:var(--success-hover)}.btn-warning{background:var(--warning);color:#1a1a1a}.btn-warning:hover{background:var(--warning-hover)}.btn-error{background:var(--error);color:#fff}.btn-error:hover{background:var(--error-hover)}.btn-outline{background:transparent;border-color:var(--border);color:var(--text-secondary)}.btn-outline:hover{border-color:var(--action);color:var(--action);background:var(--action-bg)}.btn-ghost{background:transparent;color:var(--text-light)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text)}.btn-sm{padding:.375rem .75rem;font-size:var(--text-xs)}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .6rem;font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-full);line-height:1.4}.badge-red{background:var(--error-light);color:var(--error)}.badge-orange{background:var(--warning-light);color:var(--warning-hover)}.badge-green{background:var(--success-light);color:var(--success)}.badge-blue{background:var(--action-light);color:var(--action)}.badge-gray{background:var(--bg-section);color:var(--text-light)}.badge-dot{width:8px;height:8px;padding:0;border-radius:50%;display:inline-block}.badge-count{min-width:20px;height:20px;padding:0 5px;font-size:.65rem;text-align:center;line-height:20px;border-radius:10px}.badge-icon{width:24px;height:24px;padding:0;font-size:.8rem;text-align:center;line-height:24px;border-radius:50%}.search-kbd{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:var(--bg-section);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:.65rem;color:var(--text-muted);pointer-events:none;font-family:inherit}.ui-tooltip-wrap{display:inline-block;position:relative}.ui-tooltip{position:fixed;z-index:9999;background:var(--text);color:var(--bg);padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:500;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s}.ui-tooltip.visible{opacity:1}.skeleton-shimmer{background:linear-gradient(90deg,var(--bg-section) 25%,var(--bg-hover) 50%,var(--bg-section) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-group{display:flex;flex-direction:column;gap:8px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.confirm-overlay{position:fixed;inset:0;z-index:10000;background:#00000073;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.confirm-overlay.visible{opacity:1}.confirm-dialog{background:var(--surface);border-radius:var(--radius-lg, 12px);padding:var(--space-xl);min-width:320px;max-width:90vw;box-shadow:var(--shadow-lg)}.confirm-title{font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-sm)}.confirm-message{color:var(--text-light);font-size:var(--text-sm);margin-bottom:var(--space-lg);line-height:1.5}.confirm-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-xl);transition:all var(--transition)}.card:hover{box-shadow:var(--shadow);border-color:var(--border)}.card-clickable{cursor:pointer}.card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-sm);position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;border-radius:4px 0 0 4px}.kpi-card[data-color=blue]:before{background:var(--action)}.kpi-card[data-color=red]:before{background:var(--error)}.kpi-card[data-color=green]:before{background:var(--success)}.kpi-card[data-color=orange]:before{background:var(--warning)}.kpi-card .kpi-icon{font-size:1.5rem;margin-bottom:var(--space-xs)}.kpi-card .kpi-value{font-size:var(--text-3xl);font-weight:800;color:var(--text);line-height:1}.kpi-card .kpi-label{font-size:var(--text-sm);color:var(--text-light)}.kpi-card .kpi-trend{font-size:var(--text-xs);font-weight:600;display:flex;align-items:center;gap:.25rem}.kpi-trend.up{color:var(--error)}.kpi-trend.down{color:var(--success)}.eight-d-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);padding:var(--space-lg);cursor:pointer;transition:all var(--transition);display:flex;flex-direction:column;gap:var(--space-md)}.eight-d-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--action)}.eight-d-card .case-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.eight-d-card .case-id{font-size:var(--text-xs);font-weight:700;color:var(--action);font-family:var(--font-mono)}.eight-d-card .case-title{font-size:var(--text-sm);font-weight:600;color:var(--text);line-height:var(--leading-tight);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.progress-dots{display:flex;gap:4px;align-items:center}.progress-dots .dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:all var(--transition-fast)}.progress-dots .dot.completed{background:var(--success)}.progress-dots .dot.current{background:var(--action);box-shadow:0 0 0 3px var(--action-light)}.progress-dots .dot.skipped{background:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl) var(--space-xl);text-align:center;gap:var(--space-lg)}.empty-state .empty-icon{font-size:3rem;opacity:.5}.empty-state .empty-title{font-size:var(--text-lg);font-weight:600;color:var(--text)}.empty-state .empty-desc{font-size:var(--text-sm);color:var(--text-light);max-width:320px}.alert-item{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius);border-left:3px solid transparent;transition:background var(--transition-fast)}.alert-item:hover{background:var(--bg-hover)}.alert-item.alert-error{border-left-color:var(--error)}.alert-item.alert-warning{border-left-color:var(--warning)}.alert-item.alert-success{border-left-color:var(--success)}.alert-item.alert-info{border-left-color:var(--info)}.alert-item .alert-icon{font-size:1.25rem;flex-shrink:0}.alert-item .alert-content{flex:1;min-width:0}.alert-item .alert-title{font-size:var(--text-sm);font-weight:600}.alert-item .alert-desc{font-size:var(--text-xs);color:var(--text-light);margin-top:2px}.filters-bar{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-card);flex-wrap:wrap}.filters-bar .filter-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.3rem .75rem;font-size:var(--text-xs);font-weight:500;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg);cursor:pointer;transition:all var(--transition-fast)}.filters-bar .filter-chip:hover,.filters-bar .filter-chip.active{border-color:var(--action);background:var(--action-light);color:var(--action)}.detail-back{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:var(--text-sm);font-weight:500;color:var(--text-light);cursor:pointer;transition:color var(--transition-fast);margin-bottom:var(--space-lg)}.detail-back:hover{color:var(--action)}.form-group{display:flex;flex-direction:column;gap:var(--space-sm)}.form-label{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary)}.form-input,.form-textarea,.form-select{width:100%;padding:.625rem .875rem;font-size:var(--text-sm);background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);color:var(--text);transition:all var(--transition-fast)}.form-input:hover,.form-textarea:hover,.form-select:hover{border-color:var(--text-muted)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--action);box-shadow:0 0 0 3px var(--action-bg)}.form-input.error,.form-textarea.error,.form-select.error{border-color:var(--error);box-shadow:0 0 0 3px var(--error-bg)}.form-textarea{resize:vertical;min-height:100px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.form-hint{font-size:var(--text-xs);color:var(--text-muted)}.form-error{font-size:var(--text-xs);color:var(--error)}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border)}.tab{padding:var(--space-md) var(--space-lg);font-size:var(--text-sm);font-weight:500;color:var(--text-light);border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.tab:hover{color:var(--text)}.tab.active{color:var(--action);border-bottom-color:var(--action)}.search-bar{position:relative}.search-bar input{width:100%;padding:.625rem .875rem .625rem 2.5rem;font-size:var(--text-sm);background:var(--bg-section);border:1.5px solid transparent;border-radius:var(--radius);color:var(--text);transition:all var(--transition-fast)}.search-bar input:focus{outline:none;background:var(--bg);border-color:var(--action);box-shadow:var(--shadow-sm)}.search-bar .search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:var(--text-sm);color:var(--text-muted);pointer-events:none}.dropdown{position:relative}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:var(--space-xs);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:180px;z-index:var(--z-dropdown);padding:var(--space-xs) 0;opacity:0;transform:translateY(-4px);pointer-events:none;transition:all var(--transition-fast)}.dropdown-menu.open{opacity:1;transform:translateY(0);pointer-events:all}.dropdown-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast)}.dropdown-item:hover{background:var(--bg-hover);color:var(--text)}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-modal, 1000);display:flex;align-items:center;justify-content:center;padding:var(--space-xl)}.modal{background:var(--surface);border-radius:var(--radius-card);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border);flex-shrink:0}.modal-body{padding:var(--space-xl);flex:1;overflow-y:auto}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--border);flex-shrink:0}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:var(--space-md) var(--space-lg);text-align:left;font-size:var(--text-sm);border-bottom:1px solid var(--border)}.data-table th{font-weight:600;color:var(--text-light);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.03em;background:var(--bg-section);position:sticky;top:0}.data-table td{color:var(--text)}.data-table tr:hover td{background:var(--bg-hover)}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg)}@media(max-width:1024px){.kpi-grid,.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.kpi-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.kpi-card{padding:var(--space-md)}.kpi-card .kpi-value{font-size:var(--text-xl)}.kpi-card .kpi-label{font-size:var(--text-xs)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.data-table thead{display:none}.data-table,.data-table tbody,.data-table tr,.data-table td{display:block;width:100%}.data-table tr{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:var(--space-md);padding:var(--space-md)}.data-table td{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xs) 0;border-bottom:1px solid var(--border-light, var(--border));font-size:var(--text-sm);word-break:break-word}.data-table td:last-child{border-bottom:none}.data-table td:before{content:attr(data-label);font-weight:600;font-size:var(--text-xs);color:var(--text-light);text-transform:uppercase;flex-shrink:0;margin-right:var(--space-md)}.modal-overlay{padding:0;align-items:stretch}.modal{max-width:100%;max-height:100%;height:100%;border-radius:0}.modal-footer{padding-bottom:calc(var(--space-lg) + env(safe-area-inset-bottom,0))}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap}.tabs::-webkit-scrollbar{display:none}.tab{white-space:nowrap;flex-shrink:0;padding:var(--space-sm) var(--space-md)}.filters-bar{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:var(--space-xs);padding:var(--space-sm)}.filters-bar::-webkit-scrollbar{display:none}.filters-bar .filter-chip{flex-shrink:0}.eight-d-card{padding:var(--space-md)}.modal-footer .btn{flex:1;justify-content:center}.dropdown-menu{position:fixed;left:var(--space-md);right:var(--space-md);bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0) + var(--space-md));top:auto;min-width:auto;border-radius:var(--radius-card)}.form-group{gap:var(--space-xs)}.form-input,.form-textarea,.form-select{font-size:16px}.empty-state{padding:var(--space-xl) var(--space-md)}.empty-state .empty-icon{font-size:2rem}.search-bar input{font-size:16px}}@media(max-width:768px){.btn,button,[role=button],a[class*=btn]{min-height:44px;min-width:44px}.form-input,.form-textarea,.form-select{min-height:44px}.filter-chip{min-height:44px;padding:.5rem .75rem}.data-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media(max-width:400px){.kpi-grid{gap:var(--space-sm)}.kpi-card .kpi-value{font-size:var(--text-lg)}.card{padding:var(--space-md)}.btn{padding:.5rem .875rem;font-size:var(--text-xs)}.badge{font-size:.625rem;padding:.15rem .4rem}.alert-item{padding:var(--space-sm) var(--space-md)}}.session-warning-backdrop{position:fixed;inset:0;background:#0009;z-index:9998;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.session-warning-card{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9999;background:var(--bg-primary, #fff);border-radius:var(--radius-lg, 12px);padding:var(--space-xl, 32px);text-align:center;box-shadow:0 20px 60px #0000004d;max-width:360px;width:90%;animation:slideUp .3s ease}.session-warning-icon{font-size:3rem;margin-bottom:var(--space-md, 16px)}.session-warning-title{font-size:1.25rem;font-weight:700;margin-bottom:var(--space-sm, 8px);color:var(--text-primary, #1a1a1a)}.session-warning-text{color:var(--text-secondary, #666);margin-bottom:var(--space-lg, 24px);line-height:1.5}.session-warning-text strong{color:var(--danger, #dc2626);font-size:1.5rem}.error-boundary-backdrop{position:fixed;inset:0;background:#00000080;z-index:10000}.error-boundary-card{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10001;background:var(--bg-primary, #fff);border-radius:var(--radius-lg, 12px);padding:var(--space-xl, 32px);text-align:center;box-shadow:0 20px 60px #0000004d;max-width:420px;width:90%;animation:slideUp .3s ease}.error-boundary-icon{font-size:3rem;margin-bottom:var(--space-md, 16px)}.error-boundary-title{font-size:1.25rem;font-weight:700;margin-bottom:var(--space-sm, 8px);color:var(--danger, #dc2626)}.error-boundary-message{color:var(--text-secondary, #666);margin-bottom:var(--space-sm, 8px);font-family:monospace;font-size:.85rem;word-break:break-word;max-height:100px;overflow:auto}.error-boundary-source{color:var(--text-tertiary, #999);font-size:.75rem;margin-bottom:var(--space-lg, 24px)}.error-boundary-actions{display:flex;gap:var(--space-sm, 8px);justify-content:center}.route-skeleton{padding:2rem;max-width:1200px;margin:0 auto}.skeleton-bar{background:var(--bg-secondary, #e5e7eb);border-radius:8px;animation:skeletonPulse 1.5s ease-in-out infinite}.skeleton-title{height:28px;width:40%;margin-bottom:1.5rem}.skeleton-row{height:16px;width:70%;margin-bottom:.75rem}.skeleton-row.short{width:45%;margin-bottom:1.5rem}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.skeleton-card{height:140px;border-radius:12px;background:var(--bg-secondary, #e5e7eb);animation:skeletonPulse 1.5s ease-in-out infinite}.skeleton-card:nth-child(2){animation-delay:.15s}.skeleton-card:nth-child(3){animation-delay:.3s}@keyframes skeletonPulse{0%,to{opacity:.4}50%{opacity:.8}}.dark .skeleton-bar,.dark .skeleton-card{background:var(--bg-secondary, #374151)}#app{display:flex;min-height:100vh;overflow-x:hidden;max-width:100vw}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--nav-bg);display:flex;flex-direction:column;z-index:var(--z-sticky);overflow-y:auto;overflow-x:hidden;transition:width var(--transition),transform var(--transition)}.sidebar.sidebar-mini{width:60px}.sidebar.sidebar-mini .sidebar-expand-content{display:none}.sidebar.sidebar-mini .sidebar-logo{justify-content:center;padding:var(--space-lg) var(--space-xs)}.sidebar.sidebar-mini .nav-link{justify-content:center;padding:var(--space-sm) 0}.sidebar.sidebar-mini .nav-icon{margin:0}.sidebar.sidebar-mini .sidebar-user{justify-content:center;padding:var(--space-md) var(--space-xs)}.sidebar.sidebar-mini~.main-wrapper{margin-left:60px}.sidebar-toggle{margin-left:auto;background:none;border:none;color:var(--nav-text);cursor:pointer;font-size:.75rem;opacity:.6;padding:4px 6px;border-radius:var(--radius-sm, 4px);transition:opacity var(--transition-fast)}.sidebar-toggle:hover{opacity:1;background:#ffffff1a}.sidebar.sidebar-mini .sidebar-toggle{margin:0 auto}.sidebar-tooltip{position:fixed;z-index:9999;background:var(--text);color:var(--bg);padding:4px 10px;border-radius:6px;font-size:.75rem;font-weight:500;white-space:nowrap;pointer-events:none;opacity:0;transform:translate(-4px) translateY(-50%);transition:opacity .15s,transform .15s}.sidebar-tooltip.visible{opacity:1;transform:translate(0) translateY(-50%)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-xl) var(--space-xl);border-bottom:1px solid var(--nav-border)}.sidebar-logo .logo-icon{width:36px;height:36px;background:var(--action);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#fff;font-weight:700}.sidebar-logo .logo-text{font-size:var(--text-base);font-weight:700;color:var(--nav-text-active);letter-spacing:-.02em}.sidebar-logo .logo-version{font-size:var(--text-xs);color:var(--nav-text);font-weight:400}.sidebar-nav{flex:1;padding:var(--space-lg) var(--space-md);display:flex;flex-direction:column;gap:2px}.sidebar-section{font-size:var(--text-xs);font-weight:600;color:var(--nav-text);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-lg) var(--space-md) var(--space-sm);opacity:.6}.nav-group{margin-bottom:2px}.nav-group-header{display:flex;align-items:center;gap:var(--space-md);padding:.5rem var(--space-md);font-size:var(--text-xs);font-weight:700;color:var(--nav-text);text-transform:uppercase;letter-spacing:.04em;opacity:.65;cursor:pointer;border:none;background:none;width:100%;text-align:left;border-radius:var(--radius);transition:all var(--transition-fast)}.nav-group-header:hover{opacity:1;background:var(--nav-bg-hover)}.nav-group.has-active>.nav-group-header{opacity:.85;color:var(--nav-text-active)}.nav-group-header .nav-icon{font-size:.85rem;width:20px;text-align:center;flex-shrink:0}.nav-group-header .nav-label{flex:1}.nav-group-chevron{font-size:.7rem;opacity:.5;transition:transform var(--transition-fast)}.nav-group-items{padding-left:8px}.nav-group-items .nav-link{padding-left:calc(var(--space-md) + 4px);font-size:.8rem}.sidebar.sidebar-mini .nav-group-header .nav-label,.sidebar.sidebar-mini .nav-group-header .nav-group-chevron{display:none}.sidebar.sidebar-mini .nav-group-items{padding-left:0}.sidebar.sidebar-mini .nav-group-items .nav-link{padding-left:var(--space-md)}.sidebar.sidebar-mini .nav-group-items{display:block!important}.nav-link{display:flex;align-items:center;gap:var(--space-md);padding:.6rem var(--space-md);font-size:var(--text-sm);font-weight:500;color:var(--nav-text);border-radius:var(--radius);cursor:pointer;transition:all var(--transition-fast);position:relative}.nav-link:hover{background:var(--nav-bg-hover);color:var(--nav-text-active)}.nav-link.active{background:#2563eb26;color:var(--nav-text-active)}.nav-link.active:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--nav-accent);border-radius:0 3px 3px 0}.nav-link .nav-icon{font-size:1.1rem;width:24px;text-align:center;flex-shrink:0}.nav-link .nav-label{flex:1}.nav-link .nav-badge{background:var(--error);color:#fff;font-size:.625rem;font-weight:700;padding:.15rem .4rem;border-radius:var(--radius-full);min-width:18px;text-align:center}.nav-fav-btn{margin-left:auto;font-size:.85rem;color:var(--text-muted, #94a3b8);cursor:pointer;opacity:0;transition:opacity .15s,color .15s;padding:2px 4px;flex-shrink:0}.nav-link:hover .nav-fav-btn{opacity:1}.nav-fav-btn:hover{color:#f59e0b}.nav-link .nav-fav-btn[title*=Retirer]{opacity:.6;color:#f59e0b}.nav-link:hover .nav-fav-btn[title*=Retirer]{opacity:1}.nav-group-favorites{border-bottom:1px solid var(--nav-border, rgba(255,255,255,.08));margin-bottom:4px;padding-bottom:4px}.nav-group-favorites .nav-group-header{color:#f59e0b}.nav-group-recents{border-bottom:1px solid var(--nav-border, rgba(255,255,255,.08));margin-bottom:4px;padding-bottom:4px}.nav-group-recents .nav-group-header{color:#94a3b8;font-size:.85em}.nav-group-recents .nav-link{opacity:.85;font-size:.92em}.sidebar.sidebar-mini .nav-fav-btn{display:none}.sidebar-user{padding:var(--space-lg);border-top:1px solid var(--nav-border);display:flex;align-items:center;gap:var(--space-md)}.sidebar-user .user-avatar{width:36px;height:36px;border-radius:50%;background:var(--action);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:700;color:#fff;flex-shrink:0}.sidebar-user .user-info{flex:1;min-width:0}.sidebar-user .user-name{font-size:var(--text-sm);font-weight:600;color:var(--nav-text-active);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user .user-role{font-size:var(--text-xs);color:var(--nav-text)}.main-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;overflow-x:hidden;max-width:100vw}.app-header{position:sticky;top:0;height:var(--header-height);background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-2xl);z-index:var(--z-sticky);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe6}[data-theme=dark] .app-header{background:#0f172ae6}.header-left{display:flex;align-items:center;gap:var(--space-lg)}.header-hamburger{display:none;width:40px;height:40px;align-items:center;justify-content:center;font-size:1.25rem;border-radius:var(--radius);cursor:pointer}.header-hamburger:hover{background:var(--bg-hover)}.header-title{font-size:var(--text-lg);font-weight:700;color:var(--text)}.header-breadcrumb{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--text-xs);color:var(--text-muted)}.header-breadcrumb .separator{color:var(--border)}.header-right{display:flex;align-items:center;gap:var(--space-md)}.header-action-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius);font-size:1.1rem;transition:all var(--transition-fast)}.header-action-btn:hover{background:var(--bg-hover)}.main-content{flex:1;padding:var(--space-2xl);padding-bottom:calc(var(--bottom-nav-height) + var(--space-2xl) + env(safe-area-inset-bottom,0));min-width:0;overflow-x:hidden;width:100%;max-width:100%}.bottom-nav{display:block!important;position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height, 64px);background:var(--nav-bg, #1e293b);border-top:2px solid var(--action, #2563eb);z-index:9999;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -4px 20px #0000004d}.bottom-nav-inner{display:flex;align-items:center;justify-content:space-around;height:100%;max-width:500px;margin:0 auto}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-xs, 4px) var(--space-sm, 8px);font-size:var(--text-xs, .75rem);color:#ffffffb3;cursor:pointer;transition:color .2s;border-radius:var(--radius, 8px);min-width:56px;text-decoration:none;-webkit-tap-highlight-color:transparent}.bottom-nav-item .bnav-icon{font-size:1.25rem}.bottom-nav-item .bnav-label{font-weight:600;letter-spacing:.02em}.bottom-nav-item:hover,.bottom-nav-item.active{color:#fff}.bottom-nav-item.active{background:#2563eb26}.bottom-nav-item.active .bnav-icon{transform:scale(1.15)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:calc(var(--z-sticky) - 1);opacity:0;transition:opacity var(--transition)}.sidebar-overlay.visible{display:block;opacity:1}.page-container{animation:fadeIn .25s ease}@media(max-width:1024px){.main-content{padding:var(--space-xl)}}@media(max-width:768px){html{max-width:100vw}.sidebar{transform:translate(-100%);width:min(280px,85vw)}.sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.main-wrapper{margin-left:0}.app-header{padding:0 var(--space-md)}.header-hamburger{display:flex}.header-title{font-size:var(--text-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:50vw}.header-breadcrumb{display:none}.bottom-nav{display:block;height:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0));padding-bottom:env(safe-area-inset-bottom,0)}.main-content{padding:var(--space-md);padding-bottom:calc(var(--bottom-nav-height) + var(--space-xl) + env(safe-area-inset-bottom,0))}}@media(max-width:400px){.main-content{padding:var(--space-sm);padding-bottom:calc(var(--bottom-nav-height) + var(--space-lg) + env(safe-area-inset-bottom,0))}.app-header{padding:0 var(--space-sm)}.header-title{font-size:var(--text-sm);max-width:45vw}.bottom-nav-item{min-width:48px;padding:var(--space-xs) 4px}.bottom-nav-item .bnav-label{font-size:.625rem}}.skip-to-content{position:absolute;top:-100%;left:var(--space-md);z-index:10000;padding:var(--space-sm) var(--space-md);background:var(--primary);color:#fff;border-radius:var(--radius-md);font-weight:600;text-decoration:none;transition:top .2s}.skip-to-content:focus{top:var(--space-md)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease forwards}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.fade-out{animation:fadeOut .3s ease forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .3s ease forwards}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}.slide-down{animation:slideDown .3s ease forwards}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.pulse{animation:pulse 2s ease-in-out infinite}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.scale-in{animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes slideInRight{0%{opacity:0;transform:translate(60px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-60px)}to{opacity:1;transform:translate(0)}}@keyframes slideOutLeft{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-60px)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(60px)}}.page-transition-forward{animation:slideInRight .35s cubic-bezier(.25,.46,.45,.94) forwards}.page-transition-backward{animation:slideInLeft .35s cubic-bezier(.25,.46,.45,.94) forwards}.page-transition-exit-forward{animation:slideOutLeft .3s cubic-bezier(.55,.06,.68,.19) forwards}.page-transition-exit-backward{animation:slideOutRight .3s cubic-bezier(.55,.06,.68,.19) forwards}.page-transition-fade-in{animation:fadeIn .3s ease forwards}.page-transition-fade-out{animation:fadeOut .25s ease forwards}.stagger>*{animation:slideUp .4s cubic-bezier(.25,.46,.45,.94) forwards;opacity:0}.stagger>*:nth-child(1){animation-delay:0ms}.stagger>*:nth-child(2){animation-delay:50ms}.stagger>*:nth-child(3){animation-delay:.1s}.stagger>*:nth-child(4){animation-delay:.15s}.stagger>*:nth-child(5){animation-delay:.2s}.stagger>*:nth-child(6){animation-delay:.25s}.stagger>*:nth-child(7){animation-delay:.3s}.stagger>*:nth-child(8){animation-delay:.35s}.stagger>*:nth-child(9){animation-delay:.4s}.stagger>*:nth-child(10){animation-delay:.45s}.stagger>*:nth-child(11){animation-delay:.5s}.stagger>*:nth-child(12){animation-delay:.55s}.stagger>*:nth-child(n+13){animation-delay:.6s}.stagger-fast>*{animation:slideUp .3s cubic-bezier(.25,.46,.45,.94) forwards;opacity:0}.stagger-fast>*:nth-child(1){animation-delay:0ms}.stagger-fast>*:nth-child(2){animation-delay:30ms}.stagger-fast>*:nth-child(3){animation-delay:60ms}.stagger-fast>*:nth-child(4){animation-delay:90ms}.stagger-fast>*:nth-child(5){animation-delay:.12s}.stagger-fast>*:nth-child(6){animation-delay:.15s}.stagger-fast>*:nth-child(7){animation-delay:.18s}.stagger-fast>*:nth-child(8){animation-delay:.21s}.stagger-fast>*:nth-child(n+9){animation-delay:.24s}@keyframes staggerScaleIn{0%{opacity:0;transform:scale(.8) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.stagger-scale>*{animation:staggerScaleIn .4s cubic-bezier(.34,1.56,.64,1) forwards;opacity:0}.stagger-scale>*:nth-child(1){animation-delay:0ms}.stagger-scale>*:nth-child(2){animation-delay:50ms}.stagger-scale>*:nth-child(3){animation-delay:.1s}.stagger-scale>*:nth-child(4){animation-delay:.15s}.stagger-scale>*:nth-child(5){animation-delay:.2s}.stagger-scale>*:nth-child(6){animation-delay:.25s}.stagger-scale>*:nth-child(7){animation-delay:.3s}.stagger-scale>*:nth-child(8){animation-delay:.35s}.stagger-scale>*:nth-child(n+9){animation-delay:.4s}@keyframes countUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.count-up{animation:countUp .6s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes countUpScale{0%{opacity:0;transform:translateY(12px) scale(.8)}70%{opacity:1;transform:translateY(-2px) scale(1.05)}to{opacity:1;transform:translateY(0) scale(1)}}.count-up-scale{animation:countUpScale .8s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes digitRollIn{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes digitRollOut{0%{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:0}}.digit-roll-in{animation:digitRollIn .4s cubic-bezier(.25,.46,.45,.94) forwards}.digit-roll-out{animation:digitRollOut .4s cubic-bezier(.25,.46,.45,.94) forwards}.counter-container{display:inline-flex;overflow:hidden;position:relative}.counter-digit{display:inline-block;position:relative}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer,.skeleton{background:linear-gradient(90deg,var(--bg-section, #e0e0e0) 25%,var(--bg-hover, #f0f0f0) 37%,var(--bg-section, #e0e0e0) 63%);background-size:400% 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:var(--radius, 8px)}.skeleton-text{height:14px;margin-bottom:8px;border-radius:4px}.skeleton-text:last-child{width:60%}.skeleton-title{height:20px;width:40%;margin-bottom:12px;border-radius:4px}.skeleton-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0}.skeleton-card{height:120px;border-radius:var(--radius, 12px)}.skeleton-badge{width:64px;height:24px;border-radius:12px}@keyframes skeletonPulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton-pulse{background:var(--bg-section, #e0e0e0);animation:skeletonPulse 1.5s ease-in-out infinite;border-radius:var(--radius, 8px)}.btn-ripple{position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent}@keyframes ripple{0%{transform:scale(0);opacity:.5}to{transform:scale(4);opacity:0}}.btn-ripple .ripple-effect{position:absolute;border-radius:50%;background:#ffffff59;width:100px;height:100px;margin-top:-50px;margin-left:-50px;animation:ripple .6s cubic-bezier(.25,.46,.45,.94) forwards;pointer-events:none}.btn-ripple--dark .ripple-effect{background:#00000026}.btn-ripple{transition:transform .2s ease,box-shadow .2s ease}.btn-ripple:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.btn-ripple:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}@keyframes confettiDrop{0%{transform:translateY(-20px) rotate(0) scale(1);opacity:1}10%{opacity:1}80%{opacity:1}to{transform:translateY(100vh) rotate(720deg) scale(.3);opacity:0}}@keyframes confettiSway{0%,to{transform:translate(0)}25%{transform:translate(30px)}75%{transform:translate(-30px)}}.confetti-piece{position:fixed;top:-10px;width:10px;height:10px;border-radius:2px;animation:confettiDrop 3s ease-in forwards,confettiSway 1s ease-in-out infinite;z-index:9999;pointer-events:none}.confetti-piece:nth-child(5n+1){background:#4caf50;width:12px;height:6px}.confetti-piece:nth-child(5n+2){background:#2196f3;width:8px;height:8px;border-radius:50%}.confetti-piece:nth-child(5n+3){background:#ff9800;width:10px;height:5px}.confetti-piece:nth-child(5n+4){background:#e91e63;width:6px;height:12px}.confetti-piece:nth-child(5n+5){background:#9c27b0;width:10px;height:10px;border-radius:50%}.confetti-piece:nth-child(1){left:5%;animation-delay:0s;animation-duration:2.5s}.confetti-piece:nth-child(2){left:15%;animation-delay:.1s;animation-duration:3s}.confetti-piece:nth-child(3){left:25%;animation-delay:.05s;animation-duration:2.8s}.confetti-piece:nth-child(4){left:35%;animation-delay:.15s;animation-duration:3.2s}.confetti-piece:nth-child(5){left:45%;animation-delay:.08s;animation-duration:2.6s}.confetti-piece:nth-child(6){left:55%;animation-delay:.2s;animation-duration:3.1s}.confetti-piece:nth-child(7){left:65%;animation-delay:.03s;animation-duration:2.7s}.confetti-piece:nth-child(8){left:75%;animation-delay:.12s;animation-duration:3.3s}.confetti-piece:nth-child(9){left:85%;animation-delay:.18s;animation-duration:2.9s}.confetti-piece:nth-child(10){left:95%;animation-delay:.07s;animation-duration:3s}.confetti-piece:nth-child(11){left:10%;animation-delay:.22s;animation-duration:2.6s}.confetti-piece:nth-child(12){left:30%;animation-delay:.13s;animation-duration:3.4s}.confetti-piece:nth-child(13){left:50%;animation-delay:.25s;animation-duration:2.8s}.confetti-piece:nth-child(14){left:70%;animation-delay:.09s;animation-duration:3.1s}.confetti-piece:nth-child(15){left:90%;animation-delay:.16s;animation-duration:2.7s}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;overflow:hidden}@keyframes successBurst{0%{opacity:0;transform:scale(.5)}50%{opacity:.15;transform:scale(1)}to{opacity:0;transform:scale(1.2)}}.celebration-burst{position:fixed;top:50%;left:50%;width:300px;height:300px;margin:-150px 0 0 -150px;border-radius:50%;background:radial-gradient(circle,#4CAF50,transparent);animation:successBurst .8s ease-out forwards;pointer-events:none;z-index:9998}.smooth-height{overflow:hidden;transition:height .35s cubic-bezier(.25,.46,.45,.94)}.collapsible{overflow:hidden;transition:max-height .35s cubic-bezier(.25,.46,.45,.94),opacity .3s ease}.collapsible.collapsed{max-height:0;opacity:0}.collapsible.expanded{opacity:1}@keyframes expandDown{0%{max-height:0;opacity:0}to{max-height:500px;opacity:1}}@keyframes collapseUp{0%{max-height:500px;opacity:1}to{max-height:0;opacity:0}}.accordion-expand{animation:expandDown .35s cubic-bezier(.25,.46,.45,.94) forwards;overflow:hidden}.accordion-collapse{animation:collapseUp .3s cubic-bezier(.55,.06,.68,.19) forwards;overflow:hidden}.layout-animate{transition:all .3s cubic-bezier(.25,.46,.45,.94)}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes modalOverlayOut{0%{opacity:1}to{opacity:0}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modalSlideDown{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(24px) scale(.97)}}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes toastDropIn{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes toastDropOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-100%)}}@keyframes progressFill{0%{width:0%}}.progress-fill{animation:progressFill 1s cubic-bezier(.25,.46,.45,.94) forwards}@keyframes progressIndeterminate{0%{transform:translate(-100%)}to{transform:translate(400%)}}.progress-indeterminate:after{content:"";position:absolute;top:0;left:0;width:30%;height:100%;background:inherit;border-radius:inherit;animation:progressIndeterminate 1.5s ease-in-out infinite}@keyframes checkTick{0%{stroke-dashoffset:24}to{stroke-dashoffset:0}}.check-animate{stroke-dasharray:24;stroke-dashoffset:24;animation:checkTick .3s ease forwards .1s}@keyframes statusPing{0%{transform:scale(1);opacity:.8}to{transform:scale(2.5);opacity:0}}.status-ping:after{content:"";position:absolute;inset:0;border-radius:50%;background:inherit;animation:statusPing 1.5s ease-out infinite}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.shake{animation:shake .5s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}.bounce{animation:bounce .6s ease}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}@keyframes glowPulse{0%,to{box-shadow:0 0 4px rgba(var(--primary-rgb, 59, 130, 246),.3)}50%{box-shadow:0 0 16px rgba(var(--primary-rgb, 59, 130, 246),.6)}}.glow-pulse{animation:glowPulse 2s ease-in-out infinite}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.shimmer,.skeleton{animation:none!important;background:var(--bg-section, #e0e0e0)!important}.confetti-container,.confetti-piece,.celebration-burst{display:none!important}.btn-ripple:hover{transform:none}.smooth-height,.collapsible,.layout-animate{transition:none!important}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-lg);background:linear-gradient(135deg,var(--nav-bg) 0%,#1e293b 50%,var(--action) 100%);animation:loginBgIn .8s var(--ease-out)}@keyframes loginBgIn{0%{opacity:0}to{opacity:1}}.login-card{width:100%;max-width:400px;background:var(--bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-overlay);padding:var(--space-2xl);animation:loginCardIn .5s var(--ease-out) .1s both}@keyframes loginCardIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-logo{text-align:center;margin-bottom:var(--space-2xl)}.login-logo-icon{width:56px;height:56px;margin:0 auto var(--space-md);background:var(--action);color:#fff;font-size:28px;font-weight:800;border-radius:var(--radius-card);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px var(--action-glow)}.login-title{font-size:var(--text-2xl);font-weight:700;color:var(--text);margin-bottom:4px}.login-subtitle{font-size:var(--text-sm);color:var(--text-light)}.login-form{display:flex;flex-direction:column;gap:var(--space-lg)}.login-field label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-xs)}.login-input-wrap{position:relative;display:flex;align-items:center}.login-input-icon{position:absolute;left:12px;font-size:16px;pointer-events:none}.login-input-wrap input{width:100%;padding:12px 12px 12px 40px;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg-section);font-size:var(--text-base);color:var(--text);transition:border-color var(--transition),box-shadow var(--transition)}.login-input-wrap input:focus{border-color:var(--action);box-shadow:0 0 0 3px var(--action-glow);outline:none}.login-error{font-size:var(--text-sm);color:var(--error);text-align:center;min-height:20px;opacity:0;transform:translateY(-4px);transition:opacity .3s,transform .3s}.login-error.visible{opacity:1;transform:translateY(0)}.login-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:var(--action);color:#fff;font-size:var(--text-base);font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;transition:background var(--transition),transform var(--transition-spring)}.login-btn:hover{background:var(--action-hover)}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-btn-arrow{transition:transform var(--transition)}.login-btn:hover .login-btn-arrow{transform:translate(4px)}.login-demo{margin-top:var(--space-xl);text-align:center}.login-demo>p{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--space-sm)}.login-demo-accounts{display:flex;flex-wrap:wrap;gap:var(--space-xs);justify-content:center}.login-demo-chip{padding:6px 12px;font-size:var(--text-xs);border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-section);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.login-demo-chip:hover{background:var(--action-bg);border-color:var(--action);color:var(--action);transform:translateY(-1px)}@keyframes loginShake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.login-card.shake{animation:loginShake .4s ease}.header-user{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:var(--radius);cursor:pointer;transition:background var(--transition-fast)}.header-user:hover{background:var(--bg-hover)}.header-user-avatar{width:32px;height:32px;border-radius:50%;background:var(--action-bg);display:flex;align-items:center;justify-content:center;font-size:16px}.header-user-info{display:flex;flex-direction:column;line-height:1.2}.header-user-name{font-size:var(--text-sm);font-weight:600;color:var(--text)}.header-user-role{font-size:var(--text-xs);color:var(--text-light)}.header-role-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.header-logout-btn{padding:6px 12px;font-size:var(--text-sm);color:var(--text-light);border-radius:var(--radius);transition:all var(--transition-fast)}.header-logout-btn:hover{background:var(--error-bg);color:var(--error)}@media(max-width:480px){.header-user-info{display:none}}[data-theme=dark] .login-page,html.dark .login-page{background:linear-gradient(135deg,#070d1a,#111827,#1e3a5f)}@media(max-width:768px){table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}thead,tbody,tfoot{display:table;width:100%;min-width:500px}[style*="minmax(300px"],[style*="minmax(320px"],[style*="minmax(340px"],[style*="minmax(360px"]{grid-template-columns:1fr!important}[class*=page-]{max-width:100vw;overflow-x:hidden}form,.form-group,.form-row{max-width:100%}input,select,textarea{max-width:100%;font-size:16px}.filter-row,.filters-bar,.header-actions,[class*=filter],[class*=toolbar],[class*=actions-bar]{flex-wrap:wrap!important;gap:8px}svg:not([class*=icon]){max-width:100%;height:auto}.modal-content,[class*=modal-body],[class*=dialog]{max-width:calc(100vw - 24px)!important;margin:12px}[class*=btn-group],[class*=button-group]{flex-wrap:wrap;gap:6px}[class*=card]{min-width:0;max-width:100%}[class*=kanban],[class*=board-cols]{overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}[class*=kanban-col],[class*=board-col]{scroll-snap-align:start;min-width:260px}[class*=kpi-grid],[class*=stats-grid]{grid-template-columns:repeat(2,1fr)!important;gap:8px}[class*=section],[class*=panel]{padding-left:12px!important;padding-right:12px!important}h1,h2{word-break:break-word;overflow-wrap:break-word}[class*=pricing]{grid-template-columns:1fr!important}}@media(max-width:400px){[style*="minmax(280px"]{grid-template-columns:1fr!important}[class*=kpi-grid],[class*=stats-grid]{grid-template-columns:1fr 1fr!important;gap:6px}[class*=section],[class*=panel]{padding-left:8px!important;padding-right:8px!important}[class*=card] h3,[class*=card] h4{font-size:.85rem}}
